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asrEtt-r-s^-w • t^x^ *n^n 

>K7 (2 0) 3W»H:«4«a«:4it*. 




(2) 

1 

XrAT^ot, l ©i— mJlBS 1 ©.x-ift;: 
?X?iSg (task proximate) t£XR2tiitW2<DJ-- 

liWB^©^ >£*-*©*© eioa-ifo 

7 ? -trX"*"** 2 W77'y >r—> a >£WU 

3 >fcjf LT, Wl4nfc»2 ©.x— *f©aj£W«S8B 
«rSUjVi-*SI 1 ©i— 9* • >f v^-7x-x • 7^X7" 
U>T*WL^ S9E»2©i-ifC±^n-€ p ti3ft«. flWBW 20 
1 0f-^?2 ©7*-* <h©f?g©g! 1 ©KH&WSoT 

A 0 

Hfc^T, miiaaS 1 ©f-* ^ItylBff^©^- *£©WJ 
©mJlBSfl 1 ©Bfcti. HUlBm 1 ©f-*#fiWB* 2 <dt 

[|»«S3] «#ffl2IEB©3>t:a-^ . vXxA 
Kfc^T, SulB^l©f l -5 r i:mrE^2©f'-^(!:©^ 30 
©mllBffi 1 ©Wffiti. mmm 1 ©T7*'J y-v 3 
> «t & SJES l©f-?^©7?-t?X ttSfrES 2 © 7 
7" 'J 3 VlCcfc ^fiJIH* 2 ©fW^©7 ?-feXj^ 

Kfc^T. MIHJB1 ©f'-*fcii(f!ESI2©7 , -*4:©W 
©fUfBSg 1 ©Hff(±. »c. S5IBS 1 ©77' y >r~> 3 
> J: £ ffiflBW 1©7 , ->^07^*X lifMBSi 2 ©7 
7'^-y 3 Xi«fc-5li5IBW2©f f -^^©7^-bXt 40 

Uft#H5] il#ElE«©:3>fc:*-* • i/;fA 

*tt<en©S2©J-— *fli % UK, mTlBSl© 
tf£J:^Tffl^Sft"C^*fi9IM 1 ©77" 'J $—5/ 
3 V©^-f -/tiHB*2©J.— »^ , lCJ:-^rfflC^e»^^Tl^ 

<5>b5IB^ 2 ©77' U v 3 >© * -f 7£ ©M©8 2 © 
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2 

tzfc^T. f5IB^ 2 ©Mftli. ffilBig 1 ©77" 'J 
3 >#mFfBS2©77'y^-v3 ><h[H)t;77"y 

icfc^r, *ft«i©S2©i--»ra. jek. ffliasi 

©i— y^J:^Tffl^&*lT^4fl(na» 1 ©77"'J^T» 
*/ 3 VjWKtIB* 2 ©i-if ted: oTffl^ e»nr^*(WB 
^2©77"yy-v3 v tig--?** c t tcffi^ raw 

[M#£8] fi#JSlifltt©3>t^-? ■ vXrA 
Kfc^r, fJfB^ l ©7*-^«» 1 ©7 r -f ;u • U 

|B^2©7 , -^(±^2©77^^- h 'JfcEtl 

£ftrt:fj!2©7*-* • 7 7^/^0, flJE*l©'IW« 
ti. 1E(^ i»esi©7 7-r/u- f -r h 'J fcfl&EW 
2©77^r^ • h »; t^H— 

-tn-€ t n©ajR*nfc*2©i— <f^»Lr^ noism 

©j.— tf ©fiJfcM<i:*3SftS^-r^» 2 © j.— »f - 4 > 
^-7x-x • 7'>rX7'U^^^-r^mIIBB2©a.-1f 
com 2 ©n > fcTi-^ *<atSZt S:1#at+*3 > fa 
• vXrAo 

0] H^ilBKro^vtri-^ - vxf 

-tn^ti©n>tv-^t^ 2A©j-- j y©^n^n^ 

1 o©«|EWB**#*, ^nic0gUT. gtiiBT'-^ 
AmWBS 1 ©l»«S:W1-**if ^ ^*S-rfll^«:lIttt- 

[W«3K1 1] I»*S1 OI3R©=i>ti-? ->X 

rAt^ij^T. snenttamxu, Ht. ^i©77'»; 

y-va ><D7-fV*r-i/a > • ^-f 7*^2 ©77" 'J 
ftfclCSLT. l5iB^lS^2©7rvy-V3>^ 

A„ 

»#Hi 2] fl^isatt^nvt:*-^ ->Xt 

At^ij^r, »2©i— !f©ffljt«aat±. mmm\ © 

^--WtafBS 1 ©M««cfi£oTBWaf|l 2 ©i— »f (c* 
x^J6«li«:-5©i:|l«W^B«F^aWH» 1 ©J-— 9* • 

r^»7i-x * 7 , -<x7'u-r(cWj!jD^ti> S!2©j- 
-if ©wtwiBitt, S5iE^ i ©i-if aniwafs 1 
^ic^^rfliiB® 2 <D3--y\z k&^t x ^ifi^T^:^ 
ti^sn^©tiiHW(-ra^f«H-3.-if ■ -r 
7*-x ■ f-f x^u-r s^^^ssn-sit^at-r 



(3) 

3 

miiBfflS^ 3 > tr - 9 o$*<D l 9 1 <dj-— *f © 
Slwavta-n^O, itJIBS KO^vtr*-* 10 
li," 9 1 ©«fB(w* 1 V>T-$ \ZT 0^7^h% 1 ©7 

lUESi 1 ©3 vtr^-^Ci. ffiR©» 1 <D77V>r-is 

b >tflE«o» 1 ©f-^ mie^ 1 oj.- 

^^X^^^aK*nteS2 0a.-ifO«K»^* 20 
aSr*^1-§* l *f ■ -< >^-7x-x • X 

l Or*-? twlBW 2 ©f-* fc©H©W l ©58 

tot, 

mm l (OfiFffl^milBS 2 ©B$Klfc©IW©S 3 ©H9& 
&^fc/;u-r^ «&©#£< lo©B9&Wj^T s 30 

MWBB l 4 ] 1**5 1 3 IB«©3 V f x-? • *>X 
xAUifc^T. KrEKl ©f f -**<iiffiS2©f*-*£ 
1 ©H«©#&U:» 1 ©i— m* 2 © jl 

f!lIB^2©77'U^-V3 >£|§|--T?**S2©Wffi© 40 

1 ©.x-iraS! 2 ©i-if{;:**?2B£ft;: £ 
£43S££-r£3>fx-? • vXfA, 

-i/3 >*ffl^*« 1 ©B$fffl*<, flWB» 2 oi— !f 
KS 2 ©77''J 3 >£ffl^*» 2 ©BSIBfcM LT 

2 ©i— If ? x 7i6SSfc C £ Sr«F«i:i-* n 
>b*x-? • vXri», 

B»#Sl 7] ff#«l 3IBtt0 3>fcra-* ■ vX 50 
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■/u>r«u mriBSfi i ©a.— ytc^x^je«?<c-r^r©» 

2©.x— IfWB l ©*Mfc»«8**tfcU ffi©<h*©-x- 
«f mllBSi? 1 ©x-if £ * x ? iGJSTft^ t § (ztt* 2 

©8*tt«s*«#w-*»tt©* i ©*- K*#t?z t 

D»*ai 8] ffi$£l 7fB©©=>>fx-? • vx 

fillBfll ©a>tr x-*©t51Bx-if - >?-7x- 
x • f^rn'ti, Etc 4>fc< £6 lA©S2©a 
-if^IBm 1 ©i— *ft^x^3E}8-?*-&^if 
Hi-*«KWaa«tf <:«»1-*»flF©»2 ©*- K£ 

*tt^ft©*2©3>ti-*©HaiB.x-if • -f 
7x-x ■ fVXT'Wte. mfiBSI l ^>ta-^ 

tjiBJx-if • >*-7x-x • f^ri/^w^ 

mflB^ 2 H(z** i t Sr^i-fflEW l <dj--V\z 

mtmnwmizmTK? * - 1 *w«fcf .* ^ > 

»*Bi 91 IS*3Sl 3Ett«)3>t:x-^ • i/X 

fS 2 ©J.— <fO^ 2 O n > - * * JElZ'S'A-efc 9 . 
95!B» 2^3>t'a-^i, mriB^ l © j--lf 36*ffll5* 
2 <D^-mz?A?&mT*&Zt^inmW 1 Oi-if 

KWSSi^ SBBJB 1 © n > fx - ^ ©i-if • > ^ 

[H^312 0] ER^Sl 3IB®03>fx-^ • 
xAtciJ^T. MIB^ 1 £0^-— tf^milB-x— y - -f >^ 

S$ 2 ©i— If ^©a««:HB&t * d t «TBTtB(- 

x-^ • ->XrA 0 

tAC^^t, * 2 ©i-if jft^awa* l ©i-ifi:WL 
n> !B2©J.-1f*H^Wl©J.--!f(c3*LTt«^^ 

x ^ jgg-ett < uzmm 2 ©»K«^js^*«flt* n 

[«|3RJH2 2] W^3g i 313e©=i>fx-^ • i/x 
aMRSnfc«Flffl^J---!f!6<T^-bXLr^*7*-^«:^ 

*<r*^<t< <h t 1 ^77''J^-i/ 3 >^ 

« 1 ©jL-if(D^ 1 O&Witm 2 ©J— -»f 2 ©fflS 

fc «: Jttt L TmjIBSg 1 fitfW 2 ©a.-- tf (i«H(c ^ x ^ 



5 

fflkTb*ztZifi+mttim+*'P*< fct> lo© 

Sr**rfeO % ifuiEJil 1 ©ffiat*. mJEfl 1 ©f-$\ 
ffiES 1 ©77* y >r-*/ a ftlfflaBS 1 ©BSMSrS 
fl&IB* 2 ©ffitli, btTIB^ 2Wf-^ meg 2 © 

*ft*"ft*^ £©:□>£*-* • i/XfAOi- *ft — 

M*3i 2 4 1 i tt^ Lm>m 2 3 ©*©ffiR 
©aver*-* • '>xfA(;i3t^ ^n-?n©;§iR£ 

ft. ffilH» 2 ©i— *f ©*'Jffi^I&tt©gftE© i"*;u*S 

2 5 ] 1 4^ LlftWB 2 4 ©*©£;§; 

©ziye*-* • vxxAdfc^T, mifBii&Sft/'c.x 
-tf©^«*S©5BW±. Wfflplffite©* 1 
*H*^Sl©^«affl*\ «ffl*"Tffitt©«2©U 

n*#a 2 6 1 urea 1 * ^ li*#h 2 5 

©aye*-* • yxrAtc&^T. frKSS 1 ©fi»W 

JS©jl— !ffl5fcfe©3>t * — * • vX-rAT% SI © 
a— *f ^ 9 X ? 2 ©^-^©igfSfcil&t- 

bJIHS l ©a-if ©fcafrt^ mJlBH l oa- *f tfffl^T 

i^s i oT-zy^—v g i ©ffia*&£ 

MiBg! 2 ©-x-if©*: itulESil 2 yjWH^T 
t^fg 2 £077"'; *r—y 3 y 2 ©ffit£.&£ 

mum i ©fitaswwE* 2 ©firgt^x ^jsjg-e*** 
amass i ©tta*HiMB* 2 ©test;: * x * c 
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[fft#H 2 8 ] M*31 2 7 EH©*tt(cte^T % SIR 
$ ftfc-x— if o«K««a*HW«(cBlrt * xf -y 7" 

m 

[M^H 2 9 ] f|#Ji 2 7 EKo^ffiKfe^-C. fflG 
10 »l©ffla*m»2<Ofl«(c^^^iS«-C*-6^^ 

fries i offi»cfc^r«sshfc» i ©f-* tmB 

m 2 ©ffi«{Cte^T«FS**lfc» 2<D?-9t (DOM 

bWess i ©fflBic*?^r^s*nfc» i tor 

a y © * -f 7 £ 2 ©ffi «;: i ^ t«f£ $ ft *:« 2 
20 ©77'yy-i/a >©^^7*iKDit^i:, 

milHH 1 offiWcteor**S* ftfc» 1 ©B#FB^mflBm 
2 ©ffi«c*^Tl*£S ftteS 2 ©fiFl«fc(DJt«i:, 

i ©ffia^i?^T«f«* ftfcw i <dt-9 tmzm 2 © 

30 -y 7*Ci, «HB» 1 ©f* - ^ • 7 7 -f ;l/^ifE» 2 ©t"- 

m^m 3 1 1 2 7 1BK©* ffitcte^r . buIH 

m 1 ©i-if ©ffig^mJlSS 2 ©i-if ©ffi«ic fctt-^ 

©^{t^iS^LT. mjiHS 1 <Do.-y(D®nwmizm 

IB^2©J--if©-f V^-7x-X • 

[||*JI3 2] WkO*.- 1fOfc*(03>ta-? • 
i/Xx^^iStt^. »1 ©i— «f©» l©3>tTi-^ 

tc^^r7^^xBifg^avt , i -^pj^> t j:>^'jici3 
^r. 9ffla»i©3Vt:a-^t±. rn-b-y-^tasK 
ai:^^L, C©^lUi. mi©J-»^t-^X^fijg 
-e^^m 2 ©a— <f ©BttfrtK 1 ©J-— y^a«+4tt 
iH^n-b.y-y-tcJ:oT||fTPlie<t^<i:< 1 1> 1-p©3> 
50 fa-^ • 7"a^vA^IBltLTi>0. flWBaVtTi- 



(5) 
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£ 2 j--if tcmflHH 2 © j.-- 9* #ffii>T^£!f! 2 <D7 

luES 1 ©fl»3WMB» 2 *x ?2«-i?a** 

flJIHS 1 0>ffif #bJE« 2 cDffiglc ? x ^JS«T** i 10 
tdlCgLT. huE»2©jl— *f©«JtWSSS:, HIE 

[0 0 0 1 ] 

* vi'^i-Xfcffi&t'^S'XT^Xtf^ffij (Syst 
em and Method Providing a Computer User Interface 20 
Enabling Access to Distributed Workgroup Members) 

[0 0 0 2] 

tfSii^H-i-*. 30 
[0 0 0 3] 

[fi£*(S!)fi8n £<0>H»-Ct±. ft** (workers) <D 

lt. &m<orm, mm, x&wfciz^x<Dim&$. 
*r**pjiitt(^ ^^<fe#-r^o ftaoroyx^ 
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U £<0#&l^ ^7-^ (morale) *tt*<0»JBK 
[0 0 0 4 1 ttSttftfflSHt (proximity) (i* 

t±. ?fr-7<Dimm&%tf®)^x^%zt*mMtz> 

*z\z^xW^x^% 7 ;u-7'offe tf>»£ft tc^g teg 

z>*imm±. ««i-»LT*#4»a«:*L. saw* 

[0 0 0 5] ^;u-7"o«WEMtt, ^®or a 1M^S^^ 

[0006] l^u. ^<o*©ffliaiA<a^'&b$n 

7-^r;u-7 F 3&«iSft-t?*i9tttf-5ii:*Hli»cL 
(i. 7U4i/r/U^x^ya-^, iifitcJ;^^ 

[0 0 0 7] zn&0«fi#e*<&ba*u 
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fUt'^I (video teleconferencing) tL£<OVf-tft\z 

^X$jLZ>Z.b\*?£tL\*\ 10 
[0 0 0 8] ffioT, $&Ll,X^ZV-9 r)\,-7<om 

mnizm,x* «aw^ffist-Js«Lfcflat^*fiss 

£ (task proximate, VCTXlt r^x^jlfflgj fcffW 

[0 0 0 91 KOlI^av^-^a^Tia^ 

K • 7-f K * 7x7* (WWW) izTf-kXt&lzVXDV 
© $> 7 x 7* • if-/ <\Z J; o Til« $ ft & Wfft b u 

k\ :tiCJ;oT, ffiA£H+£*aW\ ^— fffctW 
W>HcHt*IP«fc/h*4«S©3 = x-f-^ KISS;* 40 
tixLtio ^©Mfig-etiigL;^*^ • *<-*Jtz 

B^KiJ^THgt -5 ? (CM LTH^-r £ 9 X ? £ 

v 3 y^mzt^-mt^ntzD--^ • ^ >^-7x 50 
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[0 0 10] ffiX0Sfi(c(i. itftflWtt 

£3Sig£->^xb-r1-&ttf>&<fc£o *tf)#ji:LT, 
t;!/^- ■ .x— if • ^>V3 > (multi-user dungeon) 

MUD^, bfgfl (object-oriente 

d) MUD, t^^. MOO^m^ dftbtf) 

?X?Jg[p] (task-oriented) OtfWIiti: < , 
ffig^lp] (location-oriented) O^fVUK^^S^ 
1>T^£„ MOO&tfMUDtt, fft077!J ^r- 

l±, -ttlS^OT'/'J^r-i/g >tLX<D$m<DtzSblZ 
RffStlTV*. Ht^ ISt^OMOO&tfMUD 

[0 0 1 1] flSJct), £ft0ft*-pfc»Bfe&**ri-* 

<Dtz$><Dt><DX$>% 0 Sot, cn&0)iIiBti^ taste 
* x £*»r * o t J; ^ T Biffin 

[0 0 12] 

^N7'Of-;M77 , n-v 3 > (c*tiS-r « to 

Rtf&m<o9*9{zK+z^i$&Lx^zmmw* 
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11 

(awareness) ^£#Jtt£f#£^ fl £<Sft£3IM 
[0 0 13] ftgJttiU mt$\t\L *R©«4*3> 

W©7-*r7*--H±, ?X?ifflg&x— »f©rat?©a 

-x— »f ■ -f -tn^n^siat* 20 

[0 0 14] 

»^ * v K * a * X ? iESHt 

Stress. c©^©x--tm > cc-rti. #uvb 30 

•7—* (current worker) (tfirf £ £ CO 

mMfilil&VZ* 7*7.9 Y v -7 \ OTSi. 77 7 If • 
77''J y-V a V^fcfeOTyj y-v a > • 7^ > K 
7 1 3*. S^tj-XA (OMR) ©jl— if • -f v*- 
7x— X £x>tj 7 (encounter. 39) 
7-r V K7 2 0 x>#7>? • 7^ > K7 2 

*-XAtt, HI-, J'x^jES-eft*ti£»*(-H+* : ff 40 

[o o i 5] a u> r- • 7-^tc^x^ifijg^-en^n 

©tESWfcttLTti. x>*^>; . 7f >K7 2 0 
7x7 • ^-K-h©!/^, 3flJffl«rSBfc*v h7-? 50 
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-77 y7;i/*^A©lftflW\ 

[0 0 16] xv£7>? • *>-f VK72 Of*. *UV 
T>7) ^77'Vy-Va >©W-eW0»b^O"t? % x 

>*7>* ■ 7*r>K7 2 Ote. Mfr£ftT. *©B#;& 
■cauv r- • 7-*^^x^3fiffi-c*-sfit**©7>r3 

>2 2 aWonvtTi-^TfffJlUTl^ 
S£Si^^77"y y-y 3 V^ffl^t* U> h • 7- 

*^WUr*x^JSJSic^*t*(c(±^ xv* 7 >^ • 
7 -f > F 0 2 0 ti. ft i;ajttt/*M9ft#B (cue. 
4a-) ^Lt, x>£7>? • 7^f > K7 2 Ofl 

(i. *©«£*m=j*i- *7-f n>2 2*an*. *<ox 

mftblt^* A?fi&'?tite<UZ>t^ 7-T3V2 2 
ti. i>*7>* • 7-OK7 2 Oti, i 

[0 0 17] *X?2jgttti. 3^«L/:7 7 ^ 

«^ai-ffl^r^*7-ry^-i/3>. 2)^(t;^iim 

SSt±, 2 AOttJSJl^ H«F(-. B-©?-^ • 7 7 

[0 0 18] {fcKRtf^x?JEfttt©3E8t±, ±^»lf 

*77''j y-V3 >©ftJ^£3g#ILT. Rtt*77 p y^r 
-vs >Xti77"V^--">3 >©^^7 , $rffli>T[^L:T' 

7-tf«rffl^THi;WWW^-y«rSTV^. X(±. 
^T'-^^-X • 77'';y-V3 V^fflOTfRimf-? 

• f— 7 r ;i/^7^-fexLT^^Ji^S:^ti\ * 

fc. 77'';^-y 3 V«$:?$ftlt, fcfcAHi;7 
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0 . 3 WW 7 fcfc^T n - k £ 3 WW ;u Lfc 0 * 
[0 0 19] *«FMt=B8-r*»J»«:«aLr. ffiSKBr 

ti. *BS(c^x^>afi-<?*o»«. minnow 

>/»K77*X**ttJWt>*fc, ^X^iSStt 

[0 0 2 0] *f-^KI-r*WJJKl«:a«IUT. Hi; 7 7 
'J 3 W^ffl^TEy^T'- 9 (117 ? HrX LTl>&ft 

9 h , ;©*©giJ©7TW r ;Mi7^-feXLr^*tS«MS: 20 

|q|i;AIBI©*U>y«:giJ©BW*-HLrST^S 

[0 0 2 1 ] *X?iE»tett. #£797 

*««*wi-**njxfl<oy7 h7*7 • a wi*-*> : 

MnJ^T. iKBlltfflti, S?*L<1±* 7 

££<hcDT*t<S>77"y ^-Vs >Ci, rjBgS:JE»ur 
1><5J (encounter-aware) » J 3-z.btitz9 4 7<D77 

£WBrt£££##£U\ 77^)^-^3X0947 

-«{CC±. fflAtf. f-^-x, 7-K • T'n-fe 40 
•vtf\ >t-7> 3-K • =■ WW7fc£0\ «ffl©tt« 

7y^-> 3 >t#at^ 1 7* 

O2o^77' i ;y-V3 >t±. ^-n-Fn^j-— ytcwu 

[0 0 2 2 ] B2(i, a^<D^x^jagtt«)H««:H)!f 

LT^<S> 0 H2t±. ±^U/i3oc07T^^t-J;oTS 

^ffllHfciJ^Ttt. ffl*<OfiH!SMt;U 7^;UOttWcR 50 
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KJ:^T«<fcftT^*. 77 , 'jy-V 3 >(SW ( }^T 
tt, 3-7©aM^IS77 P 'jy-V 3 >L> M, NjW¥«E 

A&tfBtt, 77 ,| J^v'3>N^T, HB$ 

iCf-^^T^f^Z^n^lT^, NtN<09 

4 7<n^<077 u ^r-v a x ^jfiSHt^HI"* i 

[0 0 2 31 flaWCSt/Hli. 77*^- > 3 >LO 
^(cfcO, coLtdU f-^M77 , ^-y 3 >CH 
■f*Mft«:«ffl-r«. 77'jy—>3>Ui, 2A^ft 
UMi*. s^77 , y^> 3 vL^w^^\ X 

?'-*|;:7£-fexL"tV*#&U:. ?x 
^^£»tt©£8*affl-rs. 77''J>r-V3 >L(i. 

f - ? 7 9 -fe X L T i, ^ #p| i;«f*J £7 7 'J - V 3 
• 7-f V Yiomtl*. jEtC 77*y^r->'3 

— ^ • 7 7^Zte7?-feXLT^*J&*&-eft*. 

ttia©W(±> 77 , yy-v/3 vLat/N^Mowwwr 

7^ifT^0, f-^ • 7r>f^Z^^WWW^y 
»\<D9itLXl±* imXGRtfF 

T. HB$[C7"/yy-i/3>M*ffl^Tl^*&^* 

[ 0 0 2 4 ] **ff»*!Hfeff!|-?WU ^x^iSSHtti. 

^ntc^-pT, » 1 <0flHSM*<» 2 ©fit 

2<0fl£3iJ!a; % Sl^tiaiU^xv*^*-/^ • >K 

^izmti^> 0 ZtliU (lurking. * 

[0 0 2 5] L^U &*i§£. «ffll^H"j--6 
f«A«^ tSUMD, FSU : G^[h|-077 , ';^-v 

3 >*s*-r-6^x^jesH4©s«s:ffl^«7ry^- 

DS^Gti, 7* — 9 • 7 7-T^^7^HzXt^ 

^ Rft*B$Pfl-ec07 7-feX-C** (M*tf^ Dtis G 
(7)7^-trX^b / >LSnr7 : '-^ • 77^ ;UXlC7^-tr 
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• 7-r > K7t;:&. Sm*ti\ 

[0 0 2 6 ] ffilgMEtt, 77'V^r— VaVMKM^T 
l^-;l/'77 , »J^-V3> 

• 3-KH5S8M 

*U>^- 7^7if 

7x7- 7^71f 
ioWtt. HM^ gft£^7V>77'y^-i/ 3 >l;:# 

t> i*pj©MjKi(±affl*nT^^t^ * coast*, -f 

[0 0 2 9] »asufewtci3v>r(±. ara**~XA 
#-rs. ^n^o^-Kt-jintf. *u>h - 7-* 

• 7-##. fft©lt«M©x>*^>^ • 7^>K7 2 

afflsn*t©fcur»ffi*n-6^ x*± % *n-«i©7 
xA^ffasafeffii^js^r^ aay*-xi»^»L 

h\ ffi/h (minimal) <D=E-b\ RTjfflVtz^-Wb 
[0 0 3 0] jBMoH^fc^e-Ktt^ **7»«fcfl!si!!> 
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* [0 0 2 7] J*U:t?&^fc0J{;i\ B^©7r^-i/ 3 
[0 0 2 8] 

3- K • 77^ 

15)1:7^7" • ^-v? 

<t?z>^nrw.mh&o &&'&M^&mm*t>~x 

«^flS©St*«©x>*^>^ - 7>r>K7l^n 

30 ©ffiR<0#fc©XaE&W&+*. 

[0 0 3 1 ] xv*7>? • 7>r > K?fc*JtJ*ij£»M 

a . & * ffin* # * x 9 &mz ft & a* ^ t - 7' • 

h-> (beep tone) ^fiS^-t < *^IR 

40 [0 0 3 2] ^Hfife«llci5^Tti, x>^?7>^ • 7 
< y K7 2 0^©T^3>2 2 0iiiD-^x>^^>^ • 
7^>K7 2 0frt»©7-f 3>2 2 <B|&Sti % 

*«) . nvfrf mmtz) . 7> (3io . x 

«\ 7-f a>2 2^g3iA:^Oj:-9^iE^ai>mt-'S 
50 »MottA0^Mt*«K*. *r^K»Sn-6^i: 
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[0 0 3 3] ^-P£OB#^T*t. *U>h • 7-*(;:»L 

**Wi*nJ2W©77?*(;:J:^T\ 
Wg^i^ct^yU-if >x-V3 V • 77 h7*7tf><fc 

(i, x>£ 7 >^ * 7 ^ > K7fl)fl\PI (appearance) £ 
»J»-r*c »* U < ti^ MM*lJ-Xt*W 

m\,W%b£lzl±^ x>£7>? • 7^>K7 2 0# 

* x ? isg-ea « se*a jwss-t * z t s n * , 

Xti. HBtc-t j )T?**<fc'9<i:77 p y^—>3 vert, 
x>#7>?.- VK7 2 0t±> :n6©i-f«)* 

HI £HBSftT^*x>*7>i' - 7^>K7 2 
OfcU 3 r- ft 7 h **1-**!8©BB^fc 

[0 0 3 4] KC7*-^7-y ht»Ci^ x>*7 

• 7-f >F7 2 OtoU X^a-^nTffift^ V K7 

# (pane) 2 4©*C> * X 7iH8ftft*M<DSSi*£ 

2 6toJ:^T, fj£**3&\ *B££x*X ht-^^^ffStc 
[0 0 3 5] 3 h^7t-7-y Mi, HI-. *X 

P OBM) 3 Ofc»Sn*9j07*>K7*t>fc&-r. 
• X h «y 7\ 77^>; 'J #f\ 

[0 0 3 61 «Sf5tc. a»Rl4«R«)7-/y ^r— >a > 

&£g*T\ 3>£a-?£ 

/Tt'S l -^wjatt tfy*x • *-K3 Otcfc^TT 
t*v*X • Rett, B li:^tiw^J;o 
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*. *©S»Jl<0A*«K^7^^-frT4^«#U 

[0 0 3 7] t*>>*X • *-K3 Ott, HK> *£>S£H 
10 Hft£©1»«fcfc7?-lr;vt*. - *-K3 0 

[0 0 3 8] *I/Vh - 7-#l*. ffiR(7?flS(0«£ 

-e#«, i«)S86i-^ Xf'f «v ^ ■ 7*v7'- #*>3 
20 +Xh • ^-y-tr-v^r^^Ci:^ WP* 

Utf*SI^*>3 8^LT^r^HMi:xUtr^^ 

ti, -en^n^. t^u-f<>^-vxf^x(iT7' 

'J^T-i/aV • 7U-A7-^iIi5tt^®^^-y--tfX 
•>T>^-7x-XtCJ:oTfifltSn-5. fe*!B»0J-e 

7 7" »J v a > 2 Oi— if CO 3 > f * - ^ 
30 izm&t&mmv- * (Tbt^It-/^? ( ^i:') 

[0 0 3 9] Stcf¥L<(4. 3>^^ h ■ >4 0^ 
^ijt?ti, *U>h • 7-2Ui. x>*7>^ • 7^>K 

40 MA<*'Jfflnrffi^/N-K^*7/V7 h7xT • h 

[0 0 4 0] *U>r- • 7-*^»Lr^»©fit**A< 

»LT(±. x>^7>^ • 7-r>K7 2 0 (±. J£3i^n 
f:7^-77 htlfF^n^o H 3(^(4, SESSSftte7 

h(7)io£0Wiig?^nr^^ 0 j£3R$n^7 

50 *v h7-^ft^77' , ;y-: >a ><t^©*< ©HOJl 
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[0 0 4 1 ] fi£38^nfc7*— 7-y M?l±. iliDM** 

3T*ti. x>*7>* • 7-f VK72 Oli. $SW)7-f 
3>2 2**;S**<fc$fc»8*J'U ■ 7-* 

li, ft**? > 2 9 fcffl^T. *ffi0*Sfcffl •)»*.* 

mf, tae*ji3^ ^ ^ ^ iias^ *c a=^*s «t>«6*\ x 

fc*t?ff*0ftfl>*--2 7lc<t^T, 7-r>K7#0h 

[0 0 4 2] xv*7>* • 7-f > F7©7* — b 
x>#7 • 7w > K7 2 0 0)7*- — 7«y hSr^JOgi 

fliit&&«jfirr*. ztut, mmmm^iju 

iBKfcftO) , XU\ raj&j 

ftAfcU IWa-f • ^ >^-7x-xX^-X h 30 
□ -?£ffl^Tx>£7>? • 7-r > K7 2 0tf)iMX 

[0 0 4 3 ] BH^fc*- K©W^xv*7>^ • 7>r > 

K7 2 0 ^7t-7-y b^jffli-r^ci^^An^T, 

(^B#l^DfWK7?*:XLTl>£©£\ S&*«f*J 

^X^i£«ttO|IJgC±. 7^3>2 2±©*ft* 

x>£7>? • 7-f V K7CO b^7 , ^ES^n, 
r«£9itt\i U^x^Jg-efc^) ftHMii. tfb 

[0 0 4 4 ] *«»&^(±. St»Mt±. #£cd?x?U: 50 
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/jN^e- K-e(±. *-XAli, 'J>ft < i: t> 1 A^fit 

stt % m&timmm<»74 ?y\z.£^x$7ihti 

0. ffi/h*-H©7'f 3>1 8j6\ 7 ^r- 7?^f - 
77*y^> 3 >0 7-r V K7 1 3 tf> b *vfiz^^tl 

*ffi/h*-K^7>r:3> l 8£Hlf?L-tv*. #u>h 

ffi/h*- H • 7-f n v 1 8 tiESrStU II 5 b 
Sh-5«tii:, A^?MEl**c:fc*i*S 1 N-f*J:^(c* 

ftS©$EH«*<*l/>b ■ 7-*a)^x^ffi(BlcA* 
Ctti, 7-f 3>WB\<DBBiztjit>tj:\,\ g^co^H* 
**uvb • 7-*(i*H-«»^^^iSSH4«:5c^ i:. 7 
-f n> l 8 W\ B5 a^Sti^ctotc, *<D77>9 

[0 0 4 5] *b>b ■ 7-*36<. fft©£<Dfi£ 

HUVc^-K^g^^n. CCOif^t^ti, xv* 7 
>^ • 7-f >K7 2 Ott. ^<ffl^&tl1"^ *U>h • 

[ 0 0 4 61 ffaeasffijT?(±. «f*M*x>*7>^ • 

7-f > K7lcfc^r<nI*^^S:»J8+^itlciD*. 
J:t»-f> *x?ies-e*«ffl©ffi*Mox>*7>^ • 

7-f VK7 2 0 ^a«*n«. Hll IwTN^tlT 

a/?offi3R*©-f y-^^*n*. 
[0047] ffi/j^-KTti. '&mm, mnvtmRiz 

(C. 5/;bJL.y b 4 2(D^ J )lz > ^l/J^ : e- K$:^i-7-f a 
>X(iflS©>f y-^^«toT^ fft©t£HH©xv*7> 
^ • 7-f >K7 2 Otcis^T. H,^n^ 0 

[0 0 4 8] s&k, fieand^ai/h^-H^ftftt. ^ 
x*±ise»<c^t^^3RHtc?B^ittc**. got, a 
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[0 0 4 9] -f^T^-Ktt. fl£*M*<ffl^T^*"r 

£ 0 Lt^U xyi/'y K->-h*f'-*'<-Xft£<Dy 

7- K • rn-b'y*©J;^ 3teSiJ©7-/'J^r-i/3 VtcH 
LTtt, i©St*M(±, Hto6ft*£fc£-^4ft^ 
£<!:{>&<5 e 20 
[0 0 5 0] *^©S"J^3BSfe«Tti. ?X 
*fit*Jl©WfflpIfl6tti3Hf«lE**fiffl#. 7*f □> 
2 2©S{b(^J:-3r % ^>£7 V* • 7 >r > K 7 2 0 (i 
*>^T. *^*n*. WfflBjtBtttt, />ft < £ 4 5oco 
u^;mc#M**u 1"ftb*>. 7?7 L ^7\ HAL 
t^*. »si-r*ft\ ^ffl^tto^n^ 

T^^^ + t^ftaStttSrffl^T. {»Jl4<8ij0>ffi*Jt 
fctDStaa («*tf. Hi£> xUfcf£§ift£) fcBW&LT 

[0 0 5 1 ] flitf. ftfflWftfc^fctt. S2 0SSW 

07>f 3>2 2&. H9ic*^J:-5(^ W> 1 ©ftHM© 
i>*7 V* • 7^> K7 2 0©*tC7>f 3>2 2ai 50 
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7-f 3>2 2 at*, fUfflRTflE 
ttoaffi©u^*Ri|!fe-rs<fc'9(cMiBf*nr, 7-f3 
>2 2b©«fc^t<c*. fttc, JB 2 otSt»**a«ofi£« 

2 ©a.— *f £ *x?JH$-e6*frif-5 frKttKHSft 
<) . S20«aiJl070>tt, HtfSEBrSn. ^JA 
1*7* 3>2 2 cleft*. 
[0 0 5 21 ff*U<«. PJfflBl«tt7^3V2 
"VWiMtlt* 7x-h\ 7*7\ f-r Vyi/T'ftir^ 
WJW4fflJt«ft»*ffl^rti;. «{b*Sifcft^ 

[0 0 5 31 a«**-XA©7--*7 L ?*i' 

rA©7ay ?0#^£ftTl>£ o 3(7)'>XxAti^ * 
7 b7-? 1 2 3±T?»tt*nfc^»(7)3Vtr a -^S: 
tnftonv^-^ i o 7"tnz<y+M 

0 3<h. 7h'UX}gS»^y 1 0 5<h, f-fX^ 
U* 1 0 It, a-#;l/ftM-K7VX? 1 0 9 A 
#/£Wj*'-h lilt. *v h7-? -fV^-7x 
-X 1 1 3 fc#tf. fnfftfl)3>ta-; 1 0 1 

tlfc % t56*M©-e^X 1 1 9ft£©#>r >tw 7* 

D7*>1 1 7Stf^bf-*l 1 8*i>LT©^»ffi 
hTf^ • *y v 1 2 1 */M,T©bf7 :t ^*ffii:** 
t^o J.-ifti, *«y h7»^ • ^ >^-7x-X 1 1 
3*/TLT, LANWAN4^-;h9-?i:8a 
^ — ^ >^ • if— tTX (naming service) ^ 7"l> 
>^ I 2 7, IBft^ai 2 5, ftoavtfi-^ 1 0 
1 . XttJlHO^X h 1 3 1 ft if©, SPB-fr- 1 2 9 

td7^-fex-r* 0 a«jft3>tri-^(ctt, *a*»;7 

*;l/^7ffl-7^>r> • fcTi— • 7^^a->Xf 
^Xtt©»2[(cJ:*SPARCstation (S^ffi^) 3>tTa 
-^36<#*n*o SunSt/Solaristi. *aStfft«>Bl 

*„ -^n-en©3 vtjL-^ ion±, • 

v^XrAXtt^Solaris (Sfiffiffi) ftifoaffl^^U 
-r-f *>XtA£. • 3>f i -^?±^ 

«b©0penStep (fiSffifll) 7 >r > K 7 >f > ^Hii^tc 

liff-r*. jftamcit ^n<oa>ta-? i o i 

tt. #-©«a6H©*fflT?***. 3>t* i -? l 0 l 
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ti, *n<F*ie#G>3 1 0 llcttLT. ?v 

[0 0 5 4] ^nftoavta-^ I 0 l 07 KUX 

[0 0 5 5 ] aa^a-XA-ewu *ft-?n<z>«£**x io 

&.x— if(i^ /n'— V> • t^x^ h (person objec 
t) l3 7^Wt^ 0 /<-7> • *7v*7 Y l 3 7 0) 

ftTt^. i— if - *-A^7*-)>h I D&^OJ-- 

if^1*W©««S:, Btrr*. /<-y v ■ t^'xn 

1 3 7l±. tT-y h-7'y73ftfc-f ?KX h . 

X^'J7'h 'f-^, Ka— - t7*yi^ h (draw obj 
ect) , Xtix4X h • X h 'J (?>J) tt£<03-Vi3 
7V? • 7-f > K»!7^SS$n«i-if©BTawaaS: 
Ettts. cti&^SSMi. gi&WKXtev^aT;^ 20 
i-if^J:o-C«KE*n^. ?<©R4$3 

l o n:lor^t^»i-f*tt 

1 4 3^aSWt-JEff-f^-^©^ffl^fi 
tf>#>y h9-*afi*MME-f*. #^T, /<-7 > • * 
h 1 3 71*. #4L<«U 3>/^ hfcf-* 

* ? h 1 3 7 (DmBt, tft L < li. i-if 0>£mi£-£ 
^^+x-t:)ESLt, 4^^tifc^-V> • t^v'x 30 

[0 0 5 6 ] Hl^ V > * t7vx ? h 1 3 7 Oil 
$lZntc7-?l±, ev^X^-K'^vxni 

3 9 anuria* £fc ffasoisM-cti. t*v 

*X- *-Kl 3 9ti. .x>#7>? • 7-r VK^ 1 4 
3X^-7 > * ^-/vx^ h 1 3 7^b©ft©^7>r 
7Vh - 7-TVr-i/a >lZ&vX£j&iStl&'i-V> 
■ *-7yx? h 1 3 7±©£*- (view) -C**. b'v 40 
#X • *-Kl 3 9C±, -tn-rnwo—lffcWL-C^ a. 
-if©7;i/*-A^ tf^-;i/-7FU^ Vti 

77^'>syfftt^ j--- iftcn>^^ h-r 

* x • * - k i 3 9 rt, 83R«re6-ea "3 , *n-?na> j. 

-if*. n-*;Ki+ + .yi/j.Snfcfcry*X * *-K 

1 3 9©a>*-*>n:, mnvtmrnzx+zmm 

lzW+&Wtitii7-9 ^-v*tf>&ftif) 50 
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*\ xwu x«*e«i-+*«iBa9*iii« ^ 

-y+*y>r 7;^*-9— frnz^tbfrr* 

[0 0 5 7] fc'^*X • *-K ■ h 1 3 9 

ti. sic. a$nfcS6»*toafli (=ua-*-i/s 

xH 1 3 9 ti. WF> -;u ■ if- M X-^r U 
^©Hff©f*x^ b-y-/a»»ffi*tt^Lri^. -ft 

^fcae^-frvMi, »j©fi£**©affl-9— 

ryx^h#M^ t^yx^ h • 'J^^Xh • ^n- 
*tcS0, Sflif-^'O/NV K^*?7 

>fT>htcR1-. n-#;uft?7>r7>h#. a 

fli-9— /<t©a««:iiJSfcsB&i-*. f6©**-XAt> 
oiffi-e**. w^y-^aflKofctot-tt. *u 

*<&fiSW0/<-7> • *7*J*t V l 3 7*&B 

[0 0 5 8] *i±<9»asafc«(cj3or. ^n^n©/< 

-7 > • h 1 3 7Xtiev*X • * — K 1 3 

9(4, :n&^vx^ h*77"';^-^3 V^T* 
h^tl^-X b^ft^^^K-f^-X h>K 
— K • ?-<7'-<?£>>K ttl:J:oT, -x-ifti. 

[ 0 0 5 9] b^. ^nfnoa>tx-^ i o i 

^Tt±. gh-<Dx.>ij*>>9 ■ ^-f v 1 4 3#ffi& 
^nftl^V^^V^ • 7-f > K7 1 4 3 

(4. «^©^'-7> • *-fv*t h 1 3 7^Ha-r«r 

1 0 1 KMoT. lBR<OJi>*7>^ • 7-f > K7 1 4 
3*#^ttL. *-©^-7> ■ h 1 

3 7©*Sto«. ffi*©R«)c:ne»©7-f >K7 1 4 3 (C 
jgtl^o i>*7>^ • ^-f > K7 1 4 3tt. 

[0 0 6 0] ^W»oimt&{6ktf&i\,^&, 

(Dvtmmz 7?-trx£Wi-£o^ zmmr* # * 
«K^*a^w*y *^xAicttft-r-5iAi36<-t?s*. 

HSw^^XA^x/^^v^ - 7-f >K7tc 

ut^M*^©aft^-t:x©t©«^©t>(7)«:^*- 
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fftLCtt. ■ 7-f a V 1 8*ffl^TBfc+ 

[0 0 6 1 ] *ft«X(&/<-7 V • ^i?x^ b 1 3 7 

a*KMLT^*77U*-S/3 VI 3 Hi. -S^t> 
TCi, aa£mf$LTt^77"lf ^r-V 3 V 1 3 

ffl(3!?3 Vtfa-^ 1 0 l^b^SS^-ft^^tT 

?-tr*£ft> T7"';^r-V3Vl 3 1 ;WfflItf> 7 7 >f 7 
[ 0 0 6 2 ] ffi£tDB&£-C\ 7-T'J V a V 13 1 © 
iOl»«tt. 77^1/' *7*J*-9 b • 

Sic, aBfcS«Lro-67y , J^r-i/g VI 3 Hi, 

ttfflW'y-fe-^*:, ^l^D + ^.^yxn 
(proxy object) 1 3 Steal*. «jB>-yfe-^tt, * 

£ ft «ffly-y-fe— Vti. f-* 

[0 0 6 3 ] -en^n©aii^iSLri>^77' , jy- 

V3 VI 3 ltcfcU W/D^i/'t^xj' b l 3 5 

jmjeilti^. aa-/a*v ■ trvx ? b 1 3 5 
t±, a»sr*»uri^77 F y^— vg v 1 3 a 
a-*-><i 4 1 ^©sa^ a ~x/* m»r 

nr*V • *-f?*9 b l 3 5ti. 77 B U^-V 3 VI 3 

i^b. 77''jy-vgvi 3 nefctf-si— tf^aa 
* v • * ? b i 3 5 fle«M©^-v v * *r 

Sarn + i/ -t^yx^ b l 3 5&, *fc> *ft§# 
^S5SLT^*77" 1 ; V 3 V 1 3 107-ff>f>f 
x-f (ID) iftvX^Z. MM-?u*i/ - 
b 1 3 514. ttJB^ -vfe-i^E^T, ffi*M^/NVK 
^^77"'jy-V 3 XOT^fVf-ff ^ffij 

>f vk) u *ft£, aa-y--^i 4 lmas*. 

^lat, 77''jy-V3> 1 3 114, iit-/q 4 

1 ^iS&t;:-* >^-7x-^iI®^i\ 

[0 0 6 4 ] aa7"n*V • 9 H3 5ti,I 

\z s m*m-/u 4 1 iz s aiti«Lri^7yyy 
-v 3 v 1 3 1 ct^n^-atrvx ? b 1 3 3 

/nvK>u*«#W*. :m:J:ot, 4 Hi, 

-atrvxn 1 3 3 ^s&t^fiLT. -tnte, 2 
ct*<«jtei;:ft*. -atrvx; b 1 3 
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3^0/nvK;M4. £?£L<ti. 77"'jy-'V 3 v 1 3 

[0 0 6 5] -tn-pn©3vtra-^ 1 0 i±<o*ft-e 
noa- iftc^LT, aa-^-^i 4 l^afltsft*. 

aa*- 1 4 Hi, v? • ^ >r v K ^ 1 4 3 

m'-v v • tyvxn 1 3 7©*£j&<®BT*ttft 

xva^V* * ^>F»> 1 4 314, £ft£, |pHJ=3V 
10 fcTa-^ 1 0 liOliru + v • *7^x? b 1 3 5 

tfls©3 vti-^ 1 0 i±©aa-/n*i/ • t7vx 

ni35 £*-&**K^fcttlfij* 'y-fe-vKffioTfT 
i i-if*<2o<7>a VfcTi-* 1 0 1 Co^tVLT 

^(dj— ^ti^ 2^©aa-9--/M 4 

1 HHteLT. WOi- !f 

[0 0 6 61 aa-9--^! 4 1 tt. 3>tx-^ 1 0 1 

±©aafcjKauT^*7^'j^— vavi 3 i^jx 

20 b£*UfLT, *ftfh©7r'^-i/3>l 3 ldflB 
-f*l«B«\ -t^aayn^V ■ t7^x^ H3 5fr 
^§ttK* 0 ^-'M 4 H4, H(C ^(DsL-Viz.ftL 
XZtor'XV'r-i'a v 1 3 1 ^^7^-f * 71*** 

(ffi^y^-i/avi 3 i#, Wft-e»fFLt:^ 
*)< v k-m v^nw»^j:orfttt^*L. 7^x 

[0 0 6 7] aa-9— '<1 4 1 (±. ^r/fx-^ 1 
30 0 l±Oliro4i/ • *7vx? b 1 3 5^f>, R 
t>\ fftroaa-9— ^1 4 ttffiy 'vfe-vSrgtt 

KO, utlb^i^ -y-fe-v 1 4 7£!E«-f£„ 8a 
■/a + S/ * tT'vxn 1 3 5^e»©ttHI* -y-fe-v 
77 , 'J^r-y 3 VI 3 1 77 , 'jy-> 3 Vl 3 

fcLftfcl-fttf. 77 , ^-'>3>l 3 1 tc^^n 
^-Sk^-y^x^ h 1 3 3^©^vK;ut, 

»aiafeffiit-J3^rtt. aa-9— /<i 4 1 w\ aa 

7*a^rV * t7vx^ b l 3 5^e>(Ott»y 'y-fe-y* 

-T^X^vrti, XV* ^V^ • VK 1 ) 1 4 3(^3B 
n*7-f 3V 2 2 0D(HI?«:Si», ^^^JfiflHtSrWBrt- 

^©(c^ffl-e^^o aa-9— /<i 4 ni, ttffly 
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-%jl*7V±9 h i 3 3*r£i;*-£*. 
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Title of Invention : SYSTEM AND METHOD EtSABLXNG AWARENESS OF 
OTHERS WORKING ON SIMILAR TASKS IN A COMPUTER WORK ENVIRONMENT 

Claims 

1 . A computer system for a plurality of users and providing to a first user a visual 
"representation of selected second users who are task proximate to the first user, comprising: 

a plurality of computers, each computer having a plurality of executable applications; 

one of the plurality of computers being & first computer of a first user, the first 
computer having a first application accessing a first datum; 

each of the remaining plurality of computers being a second computer of a second user, 
each second computer having a second application accessing a second datum; and, 

the first computer having a first user interface display displaying, for any first 
application, visual representations of selected second users, the second users each selected 
according to a fust relationship between the first datura and a second datum. 

2. The computer system of claim 1. wherein the first relationship between the first 
datum and the second datum comprises the first datum being the same as the second datum. 

3 . The computer system of claim 2, wherein the first relationship between the first 
datum and the second datum further comprises the first application accessing the first datum within 
a determined length of time from mc second application accessing the second datum. 

4. The computer system of claim 2, wherein the first relationship between the first 
datum and the second datum further comprises the first application accessing the first datum at a 
substantially same time that the second application accesses the second datom. 

5 . The computer system of claim 1 , wherein each application has a type, each second 
user is further selected according to a second relationship between the type of the first application 
being used by the first user, and the type of a second application being used by the second user. 
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3 6 . The computer system of claim 5 t wherein the second relationship comprises the 

2 first application having a same application type as the second application. 

3 7. The computer system of claim 1, wherein each second user is further selected 

2 according to the first application being used by the first user being the same as a second application 

3 being used by the second user. 

1 8 . The computer system of claim 1 , wherein the first datum is a first data file stored in 

2 a first fiJe directory, and the second datum is a second data file stored in a second file directory, 

3 and the first relationship further comprises the first file directory being the same as the second file 

4 directory. 

1 9 . The computer system of claim 1 , further comprising; 

2 fox each selected second user, the second computer of the second user having a second 

3 user interface display displaying a visual representation of the first user. 

1 1 0 . The computer system of claim 1 wherein: 

2 each computer includes at least one functional component adapted to compare fee datum 

3 associated with each of two users, and provide in response thereto a signal indicating 

4 whether the data has the first relationship . 

1 11. The computer system of claim 10, wherein the functional component is further 

2 adapted to compare an application type of a first application with an application type of a second 

3 application, and provide in response thereto the signal indicating whether the first and second 
* applications are of a same type. 
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2 12, The computer system of claim 1 , wherein a visual representation of a second user is 

2 added to the first user interface display at substantially the same tune as when the first user 

3 becomes task proximate to the second user according to the first relationship, and wherein a visual 
* representation of a second user is removed from the user interface display at substantially the same 
5 time that the first user is determined to no longer be task proximate to the second user according to 
5 the first relationship, 

1 13. A computer system for a plurality of users and providing to a first user a visual 

2 representation of selected second users , comprising: 

3 a plurality of computers, each computer having a plurality of executable applications, 

4 each application having a type; 

5 one of the plurality of computers being a first computer of a first user, the first 

6 computer having a first application accessing a first datum at a first time; 

7 each of the remaining plurality of computers being a second computer of a second user, 

8 each second computer having a second application accessing a second datum at a second 

9 time; and, 

30 the first computer having a first user interface display displaying, for any first 

11 application and any first datum, visual representations of selected second users who are 

12 task proximate to the first user, where each selected second user is individually determined 

13 to be task proximate to the first user according to at least one relationship from a group 
i« comprising: 

r 

15 a first relationship between the first datum and the second datum; 

i $ a second relationship between a type of the first application and a rype of the second 

17 application; and, 

is a third relationship between the tint time and the second time. 
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3 14. The computer system of claim 13, wherein a first user is task proximate to a second 

2 user where in the first relationship: 

3 the first datum is me same as the second datum. 

1 15. The computer system of claim 13, wherein a first user is task proximate to a second 

2 user where in the second relationship: 

3 the type of the first application is the same as the type of the second application . 

1 16. The computer system of claim 1 3 , wherein a first user is task proximate to a second 

2 user where in the third relationship: 

3 the first time at which the first nser uses the first application is within a predetermined 

4 length of time to a second time the second user uses the second application. 

1 17, The computer system of claim 13, wherein the user interface display includes a 

2 first mode of operation that provides a first visual representation for all second users who are **<A- 

3 proximate to the first user, and a second visual representation when no other users are task 

4 proximate to the first user. 

1 18. The computer system of claim 17, wherein: 

2 the user interface display of the first computer further includes a second mode of 

3 operation that provides only a visual representation of whether or not at least one second 

4 user is task proximate to the first user, and, 

5 * the user interface display of each second computer displays a visual representation of 

6 the fust user indicating that the user interface display of the first computer is in the second 

7 mode of operation. 
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j 19. The computer system of claim I3 ( further comprising: 

2 a second computer of a second user, the second computer having a user interface 

$ display including a visual representation of the first user where the first user is task 

4 proximate to the second user, and the visual representation of the first user is a function of 

s a display mode of the user interface display of the first computer. 

1 20. The computer system of claim 13, further comprising a communication mechanism 

2 allowing the first user to initiate a communication to a second user represented by a visual 

3 representation in the user interface display. 

1 21. The user interface of claim 13 > wherein there is provided a first aural indication each 

2 time a second user becomes task proximate to the first user, and a second aural indication each time 

3 a second user becomes no longer task proximate to the first user, 

1 22 . The computer system of claim 13, wherein each computer further comprises: 

2 at least one application capable of providing a message specifying a position including a 

3 datum that a user is accessing at a selected time, the message provided by an active 

4 application at about the time the user changes their position ; and, 

s at least one match object that compares a first position of a first user and a second 

6 position of a second user, and provides a signal indicating whether the fust and second 

7 users are task proximate to each other, where the first position includes the first datum, (he 

8 first application, and the first time, and the second position includes the second datum, the 

9 second application, and the second time. 
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1 23 . The computer system of claim 22, further comprising: 

2 a plurality of person objects, each person object uniquely associated with a user of the 

3 computer system, each person object having a visual representation capable of being 

4 displayed in the user interface displays . 

a 24. The computer system of any of the preceding claims, wherein the visual 

2 representation of each selected second users is periodically updated to indicate a current level of 

3 availability of the second user. 
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25. The computer system of any of the preceding claims, wherein the updating of the 
visual representation of selected user replaces a first visual representation associated with a first 
level of availability with a second visual representation associated with a second level of 
availability. 

26. Hie computer system of any of the preceding claims, wherein the first visual 
representation is gradually, visually transformed into the second visual representation. 

27. In a computer system for multiple users, where each user has a display device 
having an interface display, a computer implemented method of providing an awareness of a 
second user who is task proximate to a first user, comprising: 

detennining for the first user a first position in a first application that the first user is 
using; 

dttermuiing for the second user a second position of a second application that the 
second user is using; 

detemiiriing whether the first position is task proximate to the second position; 

responsive to me fust position being task proximate to the second position, displaying 
for each user a visual representation of the other user in the interface display associated 
with each user, and 

for each user, periodically updating the visual representation of the users to indicate a 
current level of availability of the user. 

28. The computer implemented method of claim 27, wherein periodically updating of 
the visual representation of selected user comprises: 

replacing a first visual representation associated with a first level of availability with a 
second visual representation associated with a second level of availability. 
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29. The computer implemented method of claim 27 wherein determining whether the 
first position is task proximate to the second position further comprises at least one of a group of 
comparisons including: 

comparing a first datum specified in the first position with a second datum specified in 
the second position; 

comparing a first application specified in the first position with a second application 
identified in the second position; 

comparing a type of a first application specified in the first position with a type of a 
second application identified in the second position; and, 

20 comparing a first time specified in the first position to a second time specified in the 

2 1 second position. 

30. The computer implemented method of claim 27, where the first datum and second 
datum are data files in at least one directory structure, wherein comparing a first datum specified in 
the first position with a second datum specified in the second position further comprises: 

determining whether the first data file is in a same directory level as the second data file. 

3 1 . The method of claim 27 farther comprising; 
responsive to a change in the position of the fust nscr such that the position of the first 

user is no longer task proximate to the position of the second user, removing the visual 
representation of the first user from the interface display of the second user, and removing 
the visual representation of the second user from the interface display associated with the 
first user. 

32. In a computer system for multiple users* a computer readable memory accessible 
by a first computer of a first user, the first computer having a processor and a display device, the 
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3 memory storing at least one computer program executable by the processor that provides an 

4 awareness to the first user of a second user who is task proximate to a first user, the computer 

5 program controlling the processor to; 

6 determine for the first user a first position in a first application executing on the 

7 processor; 

& receive a signal indicating for a second user a second position in a second application 

9 that the second user is using; 

1 0 determine whether the first position is task proximate to the second position; and, 

11 responsive to the first position being task proximate to the second position , display a 
22 visual representation of the second user in the interface display associated of the computer 
25 of the fust user. 
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Dotailed Description of Invention 

5 

Related Application 

This application is related to the application Serial No. , filed on , entitled System and 
Method Providing a Computer User Interface Enabling Access to Distributed 
WORKGROUP MEMBERS, which is incorporated by reference herein. Both applications are 
io assigned to Sun Microsystems, Inc. of Mountain View, California. 

Background 

Field pfthfi Invention 

The present invention relates generally to the field of computer user interface design, and 
more particularly to user interfaces and methods for improved user collaboration in computer- 
is based work environments. 

pescriptipn pf ftft Background Art 

In many workplaces, a significant degree of workers* productivity is based on the ability 
to directly interact with other workers in order to exchange information about common problems, 
issues, or concerns. Informal interactions arc extremely important for workers who are members 
20 of a team or a workgroup sharing various aspects of a common project. Recent research has 
shown that while informal interactions are responsible for a significant amount of information 
flow in an organization, they are under-utilized wiih respect to how effective they are. In 
particular, recent investigations of information flow in organizations have found that when 
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people wanted to communicate information to others in the organization, they tended to 
communicate through the hierarchical management chain, using formal mechanisms, such as 
documents and presentations, even chough they did not find these mechanism to be very 
effective. On the other hand, when workers wanted to find out information from other parts of 

5 the organization, they tended to ask other workers who they knew and respected, thus, relying on 
informal interactions, particularly personal, spoken communications. This research suggests that 
informal interactions often lead to an improved sense of community in the workplace and team 
cohesion, more efficient problem solving, and an increased pool of knowledge and experiences 
among workers. This collection of knowledge and experience improves the performance of 

20 individual workers and workgroups as a whole, and often improves morale and job satisfaction. 

Physical proximity supports group work by enabling group members to enter informal, 
unplanned interactions. In particular, in working environments where group members share 
nearby offices and workspaces, there is often an awareness of which other group members are 
present This enables one group member to easily contact the other group member present and 

15 initiate a dialogue with that person on some issue of concern. The awareness of others is known 
to be important for enabling spontaneous, and impromptu interactions that in turn facilitate 
workers in coordinating their actions, and creating shared understanding of common issues. The 
ability to informally interact in this manner provides significant benefits to the. business, and the 
awareness workers have of other workers facilitates this ability to interact. 

20 Group members often have many similar or overlapping tasks to perform, and common 

sources of information or data to use in working on various aspects of a common problem. Many 
of the informal interactions between group members are directed to solving common problems in 
these tasks. Encountering colleagues in the course of these activities often provides opportunities 
for informal yet effective interpersonal communication. The awareness of other workers further 

25 facilitates the sharing of issues related to common tasks or functions. 
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However, several trends are combining 10 make it hard for work groups to stay cohesive. 
As organizations gel larger in size, members of work groups often get distributed among 
different buildings on a campus, or even to globally distributed geographical sites. Companies 
are also embracing flexible work schedules, telecommuting, and working-at-bome programs. 
5 The escalating use of computers in the corporate workplace further influences these trends. 

All of these trends combine to detract from the physical access that work groups 
traditionally shared by being in close physical proximity to each other. An increasing amount of 
group work is accomplished through electronically mediated mechanisms, such as networked 
computer systems, facsimiles, video teleconferencing and the like. While these electronic 

30 facilities can very efficiently aid the flow of raw information across physical distances that may 
separate group members, they do not provide the same rich sense of awareness and opportunities 
for interaction shared by people who work physically in the same location. 

Accordingly, it is desirable to provide a computer-based mechanism that provides to 
distributed work group members an analogue of the sense of awareness shared by workers who 

15 are physically near each other. In a desirable collaborative computer system, applications should 
gracefully provide awareness of other people who are "task proximate." Workers are task 
proximate when they are working on the same or related data, with the same or related 
applications, at about the same time. A desirable mechanism further provides a way for people 
to initiate a conversation or other encounter with another person who is task proximate and with 

20 whom they would like to interact. 

Computer implemented communication devices of many varieties arc known, but they 
fail to provide a generalized mechanism that produces an awareness of other workers having 
similar tasks for any variety of tasks. Some conventional products provide very limited 
information targeted to a specific type of application. For example, a conventional web browser 

25 for accessing the World Wide Web (WWW) can only determine if two or more different users 
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are on the same web page at the same time. Both users must have the same web browser 
application and the web page must be provided by a web server compatible with the web 
browsers. This limits the awareness of others to a very small and specific community of users 
and computing resources. Moreover, because the implementation is designed to determine only 
5 whether there is more than one user on the same web page, such a product fails to provide a 
generalized system architecture that can be used with various different applications to determine 
whether individuals are performing related tasks on related data in various time periods of use. 
Further, such products do not provide a generalized user interface that indicates the relationship 
between the tasks different workers are performing and that facilitates communication with them. 

10 Other conventional products rely on geographic models to simulate shared environments 

of a community of users. Examples of these include Afuhi-«ser Aingeons (MUDs) and A/UDs, 
object-oriented (MOOs). These mechanisms provide a virtual space through which users 
navigate, interacting with other users sharing the same room or location in the virtual space. 
These mechanisms are based entirely on a location-oriented model of the virtual space, and not 

75 on a task-oriented model. Further, MOOs and MUDs arc designed for use as their own 
environment, in a sense their own application, rather than an architecture with which other 
applications can operate and provide task proximity information. In addition, most MOOs and 
MUDs are used for entertainment purposes, and specifically to meet other users. 

Other conventional computer tools merely provide directed communication facilities. For 

20 example, email or video-conferencing products allow a user to directly communicate with other 
workers in a particular mode. However, these products provide no information about the task 
proximity of users. Rather, these tools arc intended for a user who already knows they want to 
communicate with a particular person or group of persons. Thus, they do not facilitate the type 
of spontaneous interactions enabled by an awareness of users who are task proximate to one 

25 another. 
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Summary of the Invention 

An embodiment of the present invention provides a mechanism that enables workers 
using their computers to know which other workers are "nearby" in terms of the type of work 
they are doing, such as the data they are accessing, the application they are using, and the time 

5 when such work was performed. In one embodiment, this relationship is known as "task 
proximity." One worker is "task proximate" lo another worker when both arc accessing similar 
types of data, or using similar application tools within a particular time period. The relationship 
between the data, tools, time period may be varied to accommodate different types of data and 
applications. The task proximity relationships correspond to the types of interactions fostered in 

30 physical working environments where workers share information on common tasks. The 
invention informs workers of the others who are task proximate, facilitating the type of 
spontaneous interactions found in physical working environments, since a worker who is 
working on a computer-implemented task might benefit from the awareness that other workers 
are working on similar tasks. When a worker is aware of other users in this manner, there is an 

is increased likelihood of an interaction that will support their tasks or some other related task.- 

Workers will typically be using a number of different computer applications to perform 
their job functions and goals. While different workers may be using different applications, they 
may nonetheless be performing the same or similar tasks. Accordingly, another aspect of the 
present invention provides a system and application architecture for determining task proximity 

20 between different users, operating on different machines, using different applications at different 
limes. In addition, because the ultimate goal is to facilitate interactions between task proximate 
users, the architecture of the present invention provides mechanisms for efficient and simple 
initiation of communications between task proximate users. Finally, the present invention 
provides a user interface with representations of task proximate workers, enabling each worker to 

25 easily initiate various types of interactions with other workers. 
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Detailed Description of the Invention 

The Encounter Window and Task Proximity 

Referring now tD Figure 1, there is shown one embodiment of a user interface of a 
mechanism enabling awareness of other users who are task proximate. Figure 1 illustrates the 
5 screen display, commonly called the "desktop" of a particular user, called here, the current 
worker. The desktop is produced on the display screen of the current worker's computer. On the 
desktop 10, there Is an application window 13 for a browser application, and one embodiment of 
an encounter window 20, which is the user interface portion of the encounter mechanism, The 
encounter window 20 provides a visual mechanism for informing the current worker which other 

10 workers are task proximate. The encounter mechanism further provides aural indication of task 
proximate workers. For those workers who are task proximate, the encounter mechanism 
provides a means of efficiently initiating an interaction with such workers. 

For each worker who is task proximate to me current worker, the encounter window 
20 displays an appropriate representation of the worker. In the preferred embodiment, the 

35 representation is an icon 22. The icon 22 may a bit-mapped image of the worker. In alternative 
embodiments, other forms of representation may be used, such as various graphic image formats, 
real-time video, a simple text string, or other information, depending on the level of hardware 
support available to each worker, the network bandwidth available, and the level of privacy each 
worker desires. For workers with computers including video cameras, the representation may be 

20 created by capturing a video image of themselves. For workers without video support, an icon 
can be selected from a set of icons or created by the worker, or a text string may be used. 

The encounter window 20 is periodically updated as new workers become task proximate 
to the current worker, and other workers lose their task proximity. As either the current worker 
□r other workers context switch between applications, the encounter window 20 is updated to 

25 display the icons 22 of those workers who are then task proximate to the current worker. When a 
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worker on a remote computer uses an application and becomes task proximate to the current 
worker, the encounter window 20 provides a visaal/auraj cue of same, with an icon 22 appearing 
- for the other worker in the encounter window 20. When the person is no longer task proximate 
their icon 22 is removed The encounter window 20 thereby provides a subtle indication to the 
5 current worker that there has been a change in the task proximity of other workers. 

Task proximity may be based on any of three distinct factors: 1) the application the 
worker is currently using; 2) the date the worker is accessing or manipulating; and, 3) the time ai 
which such actions occur. These factors arc variously used to define a user's position in a "task 
space." The strictest definition of task proximity is having two workers who are using a same 
10 function of the same application on the same data file at the same time. 

The definition of position and task proximity can be independently relaxed along each of 
the above listed factors. For example: 

• the application constraint may be relaxed so that workers viewing the 
same data with different applications, or application types, arc still task proximate. 

15 Examples include viewing the same World Wide Web page with different web browsers, 

or accessing the same database table with different database applications. Alternatively, 
the application constraint may be lightened so that even in the same application, two 
workers would have to be performing the same function, such using a spell checker in a 
word processor, compiling code in a compiler, and the like. Workers using the same 

20 application but performing different functions may be considered to be not proximate. 

• the time constraint may be relaxed so that workers accessing the same data 
within a predetermined time period of each other may be task proximate. For example, 
workers accessing the same stock quotation within a quarter-hour could be task proximate 
to each other. Similarly, workers accessing the same web page or email message within 

y 
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one hour, or the same word processing document within one day, could also be task 
proximate. 

• the data constraint may be relaxed so chat workers using the same 
application, but accessing different data may be task proximate For example, workers 
5 accessing different files in the same file directory with a file browser could be task 

proximate. As another example, a worker viewing the calendar of a particular person for 
a specific date would be task proximate to other workers viewing the same person's 
calendar for different dates. Similarly, when viewing a calendar on a selected date to 
schedule a facility such as a conference room, a worker would be task proximate to other 
10 workers viewing the calendar on that date and scheduling a different conference room. 

Task proximity is preferably determined with respect to an application thai is currently 
active, or most recently active. Task proximity can be determined by the applications, or by 
other software components that have information about the position of the users. This 
information is preferably provided by the applications. Applications that can provide this 
15 information are "encounter-aware,* It is preferred that applications of a given type determine 
task proximity in the same or similar manner. An application's type is generally based on the 
nature or domain of use, for example, databases, word processors, mailer, code compilers, and sd 
on. Some applications may be considered as having more than one type. For two applications of 
a given type it is preferred that there is substantially the same determination of task proximity for 
:o their respective users. 

Figure 2 illustrates a variety of task proximity relationships. Figure 2 represents a task 

»■ 

space with axes defined by the three factors described above. In the task space individual 
workers are represented by labeled circles. Along the application axis there are three encounter- 
aware applications, L M. and N. Along the data axis there are three data files, X, Y and Z. 
25 Time is continuous. Workers A and B arc both using application N to access data file Z at the 
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same time. If N and other applications of N*s type enforce this definition of task proximity, (hen 
both A and B would see each other's representation in their encounter windows, 

Workers C and H are in application L, which relaxes the data and application constraints. 
Application L applies a proximity definition such that two workers are task proximate if they are 

5 both using applicadon L or, if not both using the same application, then accessing the same data. 
Application L does impose a strict time requirement. Thus, worker C and worker H are task 
proximate since they are both in application L at the same time, but accessing different data, and 
they would both appear in each other's encounter window. In addition, application L considers 
worker H to be task proximate to workers A and B, since they arc accessing the same data file Z 

10 at the same time as H, but using different applications. An example of this situation would have 
applications L and N being different World Wide,Web browsers, and data file Z being a WWW 
page. As another example, workers G and F are using application M at the same time on 
different but related data files, and would appear in each other's encounter window. 

In one preferred embodiment, task proximity is symmetrical, so that if a first worker 

75 appears in a second worker's encounter window, then the second worker appears in the first 
worker's encounter window. This is desired in order to prevent lurking. 

However, in some instances asymmetry is preferred or necessary, for example when 
relaxing the time constraint For example, workers D, F, and G are using application M which 
employs a task proximity definition that requires the same application, but relaxes the time 

20 constraint partially, and the data constraint. In this example then, workers D and G both access 
data file X. but at different times (eg. D accesses data file X some time after G does). Thus, 
worker G would appear in worker D's encounter window, but D would not appear in G's 
encounter window. 

Worker E is using application N on data file Y at the same time that workers G and F arc 
25 in application M. However, they do not appear in each other's encounter windows because both 
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applications M and N require identity of application. These ate but a few of the types of task 
proximity relationships possible. 

While the foregoing examples refer to individual applications, the definition of task 
proximity is preferably consistent within a given type of application, regardless of the specific 
5 implementations of each instance of the application* Further specific examples of task proximity 
definitions for application classes include (but are limited to): 

Application Typft Task Proximity Definition 

text editor/word processor same data file, 

file browser same directory tree, or within one directory 

io level. 

email application same message. 

code development environment code file at same level of code tree, 

calendar browser same calendar file or same date, 

web browser same web page. 

15 The examples merely illustrate the various ways of defining task proximity for different 

types of applications. For any of these classes the time constraint has not been applied because it 
can be relaxed by varying degrees, depending on the size of the installed based, and hence the 
number of workers who may becomt task proximate in a given time period for a given data file, 
or other factors. 

iu In the preferred embodiment, the encounter mechanism provides various modes of 

• , awa^encss ,,, about other workers. The modes allow the current worker to control the degree to 
which the encounter mechanism intrudes upon his or her experience. The mode of awareness is 
specified by each worker independently, and controls both ends of the encounter mechanism, 
namely, how the encounter mechanism appears to the current worker, and how the current 

2S worker appears in the encounter window 20 of other workers. The mode of awareness may be 

.Case 2 IIS Enabling Ann rents*: Encounter 



(42) 



ftHPP 9 - 2 9 7 7 3 6 



specified as applying to all applications on the desktop, or may be specified in each application 
individually. In the preferred embodiment of the encounter mechanism, there are three modes of 
awareness for the encounter mechanism, including open, minimal, and closed. The mode of 
awareness is selected from a menu or by clicking on the mode icon 1 8. 
5 The open mode of awareness is used by workers who are receptive to interacting with 

other workers who arc task proximate. When the encounter mechanism is specified as "open," 
the worker sees the representations of workers who are task proximate, and these representations 
arc updated as workers change their task proximity. When a worker sets the encounter 
mechanism to be in the open mode, that worker's visual representation will appear in other 

10 workers' encounter window. Further, in the open mode one may obtain additional information 
about such users, such as their email address, telephone number, fax number, mail address, and 
the like, and initiate an interaction with any number of these workers, through such means as a 
video conference, email message, and the like. 

In addition to the visual representation of workers in the encounter window, an aural 

15 indication may be used to indicate each time a worker becomes task proximate, or loses task 
proximity. Different aural indications may be used for each of these events, for example, with a 
long beep tone when a worker becomes cask proximate, and a short beep tone when a worker 
loses proximity. Other sound effects may also be used. 

In the preferred embodiment, the addition or removal of icons 22 to or from the encounter 

20 window 20 is done by a visual transformation of the icons 22 as the workers become task 
proximate or lose task proximity. The visual transformation may include a fade, wipe, dissolve, 
pull, or other gradual visual effects that unobtrusively place and remove the icons 22, Such 
visual transformations more naturally reflect the gradual acquisition of awareness of the comings 
and goings of workers that workers typically have in physical workspaces. 
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At any time there may be a large variation in the number of workers who are task 
proximate to the current worker, as a consequence of the time of day, application base, network 
size, and other factors. Also, some applications arc intended to involve large numbers of 
different users simultaneously, such as video broadcasting presentation software, In order to 

5 accommodate these variations, the user may control the appearance of the encounter window. 
There are preferably at least two different ways the encounter window 20 can appear when the 
encounter mechanism is open. For applications where it is anticipated or in fact there arc a 
relatively small number of task proximate workers, the encounter window 20 displays the 
representations of these users in a compact window format Hgure 1 illustrates the encounter 

jo window 20 as it would appear with an open mode of awareness with the compact format 

In the compact format, the encounter window 20 includes the representations of the task 
proximate workers in a scrollable window pane 24. A scrollable text area 26 provides 
information about which workers have become task proximate and which have 'left* In 
addition. Ehe shared text area 26 allows the workers to communicate with each other by a text 

15 dialogue. 

The compact format further provides means for obtaining information about the task 
proximate workers, and a means for contacting one or more workers. In Figure I , the info button 
28, will bring up another window, called a business card 30, for a selected representation of one 
of the task proximate workers. The business card includes information useful for contacting the 

20 worker, such as the worker's telephone extension, mail stop, facsimile number, email address, 
and so forth. In the preferred embodiment, the business card 30 is a specific view of information 
about a worker that is stored in a globally accessible database. 

Frequently, a worker has multiple applications running, but may not be using the 
computer for some reason. As one of the goals of the encounter mechanism is to increase the 

25 likelihood that the current worker can successfully communicate with task proximate workers, 

£ase 21 15 Enabling AwnrcnBs: Encounter 

2.1 



(44) 



- 2 9 7 7 3 6 



the encounter mechanism provides information about whether other workers are currently using 
their computer. One way this information is presented is in the business card 30, which includes 
text data indicating whether or not that The worker's keyboard, or other input device, is presently 
active, as shown in Figure 1. If the worker's input device is not active, the encounter mechanism 
5 may provide cither the length of time since the last activity, or it may provide the time stamp of 
the last activity, 

The business card 30 further provides access to other information about the worker, such 
as the worker's calendar 32. The current worker may also access information such as the idle 
time of the worker, and the time since they became task proximate. The business card 30 further 

10 is useful to inform the current worker of the identity of other workers with whom a particular 
worker is interacting, thereby letting the current worker assess the propriety and likelihood of 
success in attempting to communicate with such worker. 

In addition, the current worker can initiate communications with any other worker. Such 
interactions include posting a text message to the worker owning the business card through the 

35 stick-up burton 34, or sending email to the worker through the email button 36, or initiating a 
video conference with the worker through the video-conference button 38. Each of these 
interaction formats is provided by appropriate services interfaces in the operating system or 
application framework. In one embodiment, these various services are managed by a 
communications server that interacts with a object request broker to couple the communications 

20 application (such as a video conference server) on one user's computer to a second user's 
computer. 

More particularly, a contact button 40 allows the current worker to initiate an interaction 
with one or more selected workers. In one embodiment, the current worker selects one or more 
of the representations in the encounter window, and then presses the contact button 40. The 
25 encounter mechanism, in conjunction with a communications server, then selects a 
.. ^ • \ 
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communication mechanism, such as video-conferencing, email, text chat, audio, or the like, 
depending on the available hardware/software support of each worker. Thus, if both workers 
have video capability, then a video conference is selected. If only one worker has video 
capability, and the other, audio support only, then an audio-only dialogue is initiated, and so on. 
5 For applications or contexts in which there are a large number of workers proximate to a 

current worker, the encounter window 20 may be operated in an extended format. Figure 3 
illustrates one embodiment of the extended format. The extended format is useful for 
applications such as web browsers, databases, or network broadcasting applications where many 
workers may be using the application simultaneously. 

10 In the extended format, additional functionality is provided to enhance the current 

worker's ability to find and organize representations of the task proximate workers. In Figure 3, 
the encounter window 20 is arranged to display a larger Dumber of icons 22, the current worker 
may switch to a display of names using the radio button 29. This produces the display in Figure 
4. The current worker may then son the set of workers by any number of keys 27. including the 

15 worker's name, the lime at which the worker became task proximate (either most recent or least 
recent), the Idle times of the workers, or the interaction activity, with workers who are interacting 
with each other appearing at the top of the window pane. This last sort key enhances the 
collaborative nature of the encounter mechanism, allowing each worker to see both those other 
workers who are task proximate and those who are interacting. The worker may also search for 

20 specific workers, again, using a variety, of search keys, such as personal information, including 
name, location, department, and the like, or other information, such as activity level, and the like. 

The formats of the encounter windows are associated with particular functionality. Since 
in any application the number of users may vary, the current worker can switch beiwcen formats 
of the encounter window 20 to control functionality, as additional workers -enter" (become task 

25 proximate) or "leave" (Jose task proximity) the current worker's personal task space. Switching 
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between formats may be implemented in numerous ways, including re-sizing the encounter 
window 20 with a suitable user interface element or keystroke. 

In addition to controlling the format of the encounter window 20 during the open mode, 
in one embodiment the worker may also control the sensitivity of the task proximity display, so 

5 that the user can distinguish whether a given worker is accessing the same data at the same time, 
same data at different times, different but related data at the same time, or the like. This allows 
the user to assess the significance of the task proximity of each worker. These degrees of task 
proximity may be indicated by different color borders on the icons 22, different border patterns, 
or positioning of the icons 22, or other visual attributes. For example, using position as a 

10 indication of degree of task proximity, the "closer" (more task proximate) workers would placed 
at the top of the encounter window, and the "farther" (less task proximate) workers would be 
placed at the bottom- 
In some instances, a worker may only want to be peripherally aware of others in the task 
space in order to concentrate on a particular task or for other reasons. The current worker may 

15 then place the encounter mechanism in its minimal mode. In the minimal mode, the encounter 
mechanism provides an indication only of whether or not at least one other worker is task 
proximate, but not who the task proximate workers are. This indication may be provided by a 
simple, relatively small icon. Figures 5a and 5b illustrate an example of the minimal mode, with 
the minimal mode icon 18 displayed at the top of the window 13 for a web browser application. 

20 Figure 5a illustrates the minimal mode icon 1 8 showing that no other workers are task proximate, 
with the icon of a person being hollow. The first time the current worker becomes task 
proximate to another worker, the minimal mode icon 18 is updated to suggest a person being 
present, us shown in Figure 5b. Other workers entering the current worker's task space do not 
cause a change in the icon. When the last worker loses task proximity to the current worker the 

25 icon 18 reverts to its blank state as shown in Figure 5a, In addition, the minimal mode optionally 
„- -> 
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includes aural indications cornmenscratfl with the visual ones, with distinct tones for when a 
worker enters the task space and for when a worker leaves the task space. 

Finally, the current worker may not be interested in being aware of any other workers at 
all. Accordingly, a closed mode is provided in which the encounter window 20 is not used at all, 

5 and the current worker receives no information about the task proximity of other workers . 

In the preferred embodiment, in addition to controlling what a worker sees in their 
encounter window, the modes further control what other workers see of the particular worker In 
the open mode, a worker's representation, whether image, video, or the like, is provided to the 
encounter windows ZO of other workers who arc task proximate. The representation is as shown 

10 in figure 1 , with the images of the various workers. 

In the minimal mode, a worker desires to be only minimally aware of other workers, and 
this desire is communicated to other workers who are task proximate. Accordingly, a worker in 
the minimal mode is seen in other worker's encounter window 20 with an icon or other image 
representative of the minimal mode, such as a silhouette 42» shown in Figure 1. 

15 Finally, when a worker is in a closed mode, no representation is provided to other task 

proximate workers, again, consistent with the first worker's intention to not receive or send this 
state information. Accordingly, the mode of the encounter mechanism is preferably symmetric 
with respect the information provided to, and received from, other workers. Alternatively, the 
worker can specify for each mode the type or degree of information to be provided back to other 

20 workers. 

All the modes may be specified for all applications that a worker is using, or individually 
for each. For example, a worker may desire to be in an open mode for a web browser, and desire 
to know which other workers are proximate to the web page, since this may provide further 
useful information about the activity or task in which the worker is engaged. However, in a tool, 
25 such as a spreadsheet or database, or the like, the worker may desire to be in a minimal state, 
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merely knowing if anyone else is also working on a similar task. Finally, for another application, 
for example, a word processor, the worker may not want to be disturbed at all. 

In another alternate embodiment of the present invention, further information about the 
availability of workers who are task proximate may be displayed in the encounter window 20 by 
5 variations in their icons 22. Availability may be usefully divided Into at least five levels: active, 
idle, engaged, do not disturb, and absent For each of these levels of availability, there may be 
assigned a default icon or a user defined icon, each of which visually and distinctly suggests or 
indicates the associated level of availability. Exemplary icons 22a-e associated with distinct 
levels of availability are illustrated in Figure 9. The level of availability is determined in one 

W embodiment as a function of the worker's use of their computer,, for example, by monitoring 
their keyboard activity, and using the keyboard inputs per unit of time as a metric for 
determining the current level of availability. Additionally, the worker's computer and its 
interconnection with the computer network's communication architecture may be used to 
determine whether a worker is engaged in an interaction <cg.. telephone, video-conference) with 

15 another worker. Procedurally, after a worker is determined to be task proximate the worker's 
icon 22 is updated to reflect their current level of availability. As long as the worker remains 
task proximate, their icon 22 is periodically updated to reflect their current level of availability. 

For example, in a typical instance, a second worker will become task proximate to a first 
worker while being at an active level of availability. Accordingly, the second user's icon 22 will 

20 be illustrated in the first user's encounter window 20 with icon 22a, as in Figure 9, or the like. If 
after a period of time while the second user is still task proximate to the first user, the second 
user becomes idle, then the icon 22a will be updated to reflect this current level of availability, 
such as with icon 22b. Later if the second worker then enters into an interaction with another 
worker (regardless of whether that other worker is task proximate to either the first or second 

25 user), then the second worker's icon is again updated, for example to icon 22c. 

Cast 2115 Enabling Awn renew: Encounter 

26, 



(49) 



9 - 2 9 7 7 3 6 



Preferably, the changes in the level of availability icons 22 are made using gradual visual 
transformations, such as fades, wipes, dissolves, and the like, to reduce the obtrusiveness of the 
change. The use and implementation of level of availability information is further described in 
the related application referenced above. 



Referring now to Figure 6, there is shown a block diagram of one system providing an 
encounter mechanism. The system includes a number of computers 101 connected on a network 
123. Each computer 101 includes a processor 103. an addressable memory 105, a display 107, a 
local hard disk 109, input/output ports 111, and a network interface 113. Each computer 101 

70 further preferably has coupled to its I/O ports a conventional mouse 1 1 9 or other pointing device. 
Additionally, computers 101 may include audio capability through a microphone 117 and 
speaker 118. and video capability through a video camera 121. Users connect to the network 
123, such as a LAN, WAN, or the like, through the network interface 1 13, and access remote 
servers 129. such as naming service, printers 127 t storage devices 125, or other computers 101, 

IS or remote hosts 131. A suitable computer includes a SPARCstation™ computer manufactured 
by Sun Microsystems, Inc. of Mountain View, Ca. 1 Any other general purpose computer may 
also be adapted for use with the invention. Each computer 101 executes a general purpose 
operating system, such as Sun Microsystems' Solaris™ operating system, with the OpenSiep™ 
windowing environment from Next Computer. Typically, each computer 101 is dedicated to a 

20 single worker, though a computer 101 may support multiple workers accessing various different 
applications as servers to clients on their own computers 101. r 



' Sua and Solans are trademarks, or registered trademarks of Sua Microsystems, Inc., in the United Saxes 
and Other cou a tries. All SPARC trademarks are used under license and arc trademarks or registered trademarks of 
SPARC Iniernaifoul. Inc. in the Unlied Stales and other countries. Products bearing SPARC trademarks am based 
upon an architecture developed by Sun Microsystems, Inc. 
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The addressable memory 105 of each computer 101 further includes software components 
useful for implementing the encounter mechanism for one embodiment of the present invention. 
* Figure 7 illustrates an object model of the architecture of the encounter mechanism. 

In the encounter environment, each worker or user has a person object 1 37. A reference 

5 to the person object 137 stores user specific information, such as their user name, account ID. 
and the like, as conventionally used to create a user handle. The person object 137 further stores 
the desired representation of the user, as displayed in the encounter window, such as a bit- 
mapped image. Postscript daia, draw object, or text string. These representations may be created 
automatically or manually, and may be modified by the user. In a preferred embodiment with a 

lo large number of users distributed across many different computers 101, there will be a high 
amount of network communication devoted to periodically updating the encounter windows 143 
of each worker. Accordingly, person objects 137 preferably have a compact data structure to 
reduce the amount of information that is passed between the various components of the 
encounter mechanism. A reference to the person object 137 is preferably stored in a centralized 

75 database 129 such as a naming service which provides a handle to a given user's person object 
1 37 in response to a query presenting the user's name. 

In addition, selected data of a person object 137 may be viewed through a business card 
object 139. In a preferred embodiment, the business card 139 is a view on a person object 137 
generated by either the encounter window 143 or other client applications from the person object 

20 137. The business card 139 displays for each user information useful for contacting the user, 
such as the user's full name, address, email address, telephone number, facsimile number, and 
the like. In the preferred embodiment, the business cards 139 are extensible, and allow each 
worker to define one or more new fields for storing additional information about other workers in 
u locally cached business card 139 component. Such information could be either sialic data 
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about the individual {e.g. their pager number) or functional information that facilitates an 
interaction (e.g. a reference to a service that dials the pager). 

The business card object 139 further includes methods for initiating communications with 
the represented worker. The business card object J 39 integrates with existing desktop 
5 communications facilities, such as email services, video conferencing, and the like. Generally, in 
a distributed computing environment a user's local communication client would pass an object 
reference of a communication server of another worlcer to an object request broker, which then 
returns the handle of the communication server to the client. The local client then initiates the 
communication directly with the communication server. Other mechanisms are also possible. 
10 For email communicanon, for example, (he current worker would request the email address of 
another worlcer from the person object 137 of that worker, and pass it to a mail tool, which then 
creates an email message to the recipient. 

Also in the preferred embodiment, each person object 137 or business card 139 is a 
pasteboard type that allows these objects to be cut and pasted between applications, so that users 
15 can pass the information about workers between each other through the communication services. 

There is further provided on each computer 101 a single encounter window 143. Each 
encounter window 143 displays representations; such as icons 22. associated with various person 
objects 137. Across multiple computers 101 there will be multiple encounter windows 143, and 
so the representation of a single person object 137 may appear in any number of these windows 
20 143. The encounter window 143 provides the functionality described above regarding the modes 
of awareness, the communication abilities, and the representation of workers therein. 

While enabling awareness of. and communication with, other workers is desirable, 
worker should be able to control who has access to him in order to maintain and enhance a sense 
of privacy. In this embodiment, the present invention provides sufficient mechanisms for salient 
25 cues of a worker's availability, so that other workers can rely on social mechanisms of protecting 
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individual privacy. In addition, the specific mechanisms are provided in the encounter window 
to control which other workers have access to the current worker. The worker may enable or 
disable various ones of the communication services, such as video-conferencing, to control the 
degree to which he may be contacted by other workers. In addition, the user can control the level 
S of awareness, by selecting either (he open, minimal, or closed mode, preferably with the mode 
icon 18. 

Each person object 137 is indirectly known to one or more encounter- aware applications 
131. Generally, each encounter-aware application 131 is used by a single worker at a time. 
However, in an alternate embodiment, an cncounter-awarc application 131 may be accessed by 

10 multiple users from other computers 101 , the application 131 being a server to remote clients. 

At any point in time, a user of the application 1 3 1 is accessing a particular function and 
particular data. This information may be represented by file names, object names, pointers, or 
other means. Each time a user changes the function or data being used, the encounter aware 
application 131 sends a status message to its encounter proxy object 135. The status message 

IS specifies the data or function the worker is currently using, or combination of these elements. 
The status message may be a string with the name of the data fi!e(s), and a reference to a 
function, and can include additional information useful to determining each user's position. 

Associated with each encounter-aware application 131 is an encounter proxy object 135. 
Trie encounter proxy object 135 provides the encounter-aware application 131 a communication 

20 mechanism to the encounter server 141. The encounter proxy object 135 accepts from the 
application 131 a status message describing the user's current position in the application 131. 
The encounter proxy object 135 is able to obtain a handle to the person object 137 of the worker. 
The encounter proxy 135 also knows the identity of the application 131 with which it is 
associated. The encounter proxy object 135 binds the worker's handle, and application identity 



Case 2115 Enabling Awareness: Encounter 

*0 



(53) 



«fBB¥ 9 - 2 9 7 7 3 6 



with the status message and passes it to the encounter server 141. In this manner, the application 
131 does not have to interface directly with the encounter server 141 . 

The encounter proxy 135 further provides to the encounter server 14 1 a handle to a match 
object 133 included in the encounter-aware application 131. This allows the server 141 to 

S directly communicate with the match object 133 and pass to it user position data for a 
determination of the task proximity of two users. The handle to the match object 133 is provided 
to the encounter server 141 preferably when the application 131 is executed as a new process. 

For each user on each computer 101 there is provided an encounter server 141. The 
encounter server 141 informs the encounter window 143 of a given user when a representation of 

10 person object 137 has to be updated. The encounter server 143 does this according to status 
messages received from encounter proxy objects 135 on the same computer 101, and from 
encounter servers 141 on other computers 101. If a user is logged on to two computers 101, 
there are two encounter servers 141 for the user. Similarly, there may be multiple servers 14 1 on 
a single computer for multiple users. 

15 An encounter server 14 1 maintains a list of the encounter-aware applications 131 on the 

computer 101, receiving the information about each application 131 from its encounter proxy 
135. The server 141 further maintains information identifying which application 131 is currently 
active (other applications 131 may be operating in the background) for the user. This 
information is provided by the windowing environment, and is updated from time to time as the 

20 active application 131 changes. 

The encounter server 141 receives the status messages from the encounter proxy objects 
135 on its computer 101, and from other encounter servers 141, and stores these status messages 
147. The status messages from the encounter proxy objects 135 identify the application 131. the 
user's position in the application 131, and the user"s handle and position, and a handle to the 

25 match object 133 contained in the application 131, if any. In the preferred embodiment, when 
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the encounter server 141 receives a status message from an encounter proxy object 135, it adds a 
rimestamp to it. The timestamp.is useful for ordering the appearance of icons 22 in the encounter 
window 143. and determining task proximity. The encounter server 141 then sends the status 
message to all other encounter servers 141 on the network 123. 
5 When the encounter server 141 receives a status message, it compares the received 

message with stored status messages 147 and identifies status messages that include the same 
application type or application name, or other matching criteria, and sends the position data 
included in such status messages to a match object 133 for determining whether the users 
specified in the status messages are task proximate according to their positions. The encounter 

20 server 141 preferably invokes the match object 133 of the currently active application 131, 

In a preferred embodiment, the determination of task proximity is made by a match object 
133. Each application 131 may have a match object 133 that applies a task proximity rule 
particular to the type of application. In addition, the encounter server 141 may also have its own 
library of match objects 133, each one particularly adapted to determining task proximity for 

75 different types of applications 131. 

Where an application 131 does not have a match object 133, it may indicate to the 
encounter server 141 the type of match object 133 to use from a library, such as indicating a file 
name comparison, or a file name and application type, or a file name and time stamp, or any 
other combination of data. If the application 1 3 1 does not indicate the type of match object 133 

20 to use, the encounter server 141 preferably uses a match object 133 that performs a simple string 
comparison. 

Where the application 131 has a match object 133, the application 131 piefcrably 
registers the match object with the encounter server 141 through the encounter proxy object 135, 
with the encounter server 141 receiving and storing a handle to the match object 133. When the 
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encounter server 141 wants a determination of task proximity, it uses the handle to invoke the 
match object 133 of the currendy active application 13 L 

In an alternate embodiment, when encounter-aware application 131 starts, its match 
object 133 is copied down to the encounter server HI, thereby migrating the match object 133 to 
5 the encounter server 141. This embodiment supports a relatively fast implementation. 

The match object 133 receives from the server 141 two status messages, one describing 
the user's current position, and one describing the position of another user, typically on a second 
computer 10 1. The match object 133 determines whether the users are task proximate to each 
other, using a predetermined task proximity function. The task proximity function may be a 

30 string comparison between the position data for each user, or a more complex function including 
arithrnauc or Boolean comparisons of the time stamps, data files, -and the like. 

The match object 133 returns an appropriate status value indicating whether or not the 
two users are task proximate, or alternatively, indicating one of several possible levels of task 
proximity, as set forth above. With the result from the match object 133, the encounter server 

J5 141 informs its encounter window 143. The encounter window 143 then updates its display, 
cither adding a new representation for the task proximate worker, deleting an existing one, or 
making no change at all. 

On each computer 101 there is provided an activity monitor 145. The activity monitor 
145 monitors keyboard, mouse, and other input devices to determine whether the worker is 

zo currently using the computer 101. If there is no activity for a predetermined length of time, the 
activity monitor 145 sends a message to the encounter server 14 1 that the user is idle. This status 
message includes a handle to the person object of the user, the machine identification number of 
the user, and an active/idle flag. The encounter server 141 then sends a status message 10 all 
other encounter servers 141 on the network 123 indicating the user is not active. The other 

2S encounter servers 141 update their encounter windows 143 accordingly. When another worker 
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brings up the idle worker's business card 139, it will indicate that the worker is not active. When 
a user becomes active again, the activity monitor 145 sends a status message with an active flag 
to its encounter server 141, which again broadcasts the status message to the network 123. 

An example of the operation of the encounter mechanism is illustrated in Figure 8. 
S Assume two workers, A and B, who may be on separate remote computers or on the same 
computer. Each worker has an encounter aware application, here an editor 131a, !3Ib, which 
contains an encounter proxy object 135 and a match object 133. Each application 131 is 
preferably built with an application framework that provides notifications when the application 
131 becomes active. Each worker has their own encounter server 141a, 141b, and encounter 

10 window 143a, 143b. Each encounter server 141 has a handle to the match object 133 of the 
application 131 being used by the worker associated with the server 141. All communication 
between the computers 101 is through the encounter servers [41. Each worker is assumed to 
have their respective encounter windows 143a, 143b in open mode. In this example, the match 
object 133 is associated with the enoountcr-av/arc application 131, though as noted above, it may 

15 be associated with the encounter server 14 1 . Also, the activity monitor i 45 is not shown for case 
of explanation. * 

Worker B is currently working 800 in his application 131b, as editor, on data file Y. 
Worker A starts 801 her application 131a, also an editor, making it the active application on her 
computer. The editor 131a, via the application framework, informs 803 the encounter proxy 

20 object 135a that the editor 1 3 la is active. The encounter proxy object 135a sends 807 a status 
message to the encounter server 141a, indicating that the editor 131a is active. The status 
message includes the name of the editor 131a, a null position, and a handle to the match object 
133a associated with the editor 131a. The position is originally null since worker A has not yet 
selected a data file to edit. A null position indicates that worker A cannot be task proximate to 

25 any other worker at that time, and hence worker A will not appear in any other worker's 
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encounter window 143, nor will any other worker appear in worker A's. encounter window 1 43a. 
The handle to the match object I33a is used to register that object with the server 141 a. 

The encounter server 141a stoics 809 as a status message B12a a handle for the editor 
131, including the editor name t the match object 133a, and worker A's position. As a worker can 

5 have only one application active at a time, this information describes worker A's current 
application and position. Worker A's encounter server 141a sends 811 a message to the 
encounter window 143a indicating the current position of worker A. Since the position is null, 
there is no need to invoke a match object to determine the task proximity of other workers, and 
so the encounter window 143a clears all current icons 22 or other workers. Storing a handle of 

io the match object I33a enables the encounter server 141a to subsequendy invoke that object for 
determining task proximity between worker A and other workers. 

The encounter server 141a also rmxJticasts 813 a status message to all other encounter 
servers 141 on the network. This status message includes a handle 812 to worker A's person 
object 137a, an identification number for the computer executing the encounter server 141a, 

15 which is worker A's computer, a tirnestamp generated by the encounter server 141a. the name of 
the editor 1 31a, and the position of worker A, which is null. 

Worker B's encounter server 141b receives this status message. This encounter server 
141b searches 815 its stored status messages 812b, attempting to match the worker A's handle, 
and worker A's machine identification number to previously received status messages. These 

20 .stored messages include a status message indicating that worker B is at position Y. If there is u 
previously stored status message, then this means that worker A may have been task proximate to 
worker B at some point in the past. Accordingly, the encounter server 141b further determines 
817 if the encounter window ]43b is displaying a representation of worker A, such as an icon or 
other image. If so, the encounter server 141b sends a message to the encounter window !43b to 

25 remove the representation of worker A, since because of her null position, she is no longer task 
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proximate to worker B, regardless of what worker B is doing. The encounter window 143b 
accordingly updates itself. If there was no previously stored message, then the encounter 
window 143b need not be updated. 

The encounter server 143b stores 819 the status message for worker A, replacing any 
5 previous status message about worker A. Since, worker A's current position is null, there is no 
need to determine whether worker A is task proximate to worker B. 

Worker A now loads 821 data file X and begins editing it. Worker As editor 13 la sends 
803 a message to its encounter proxy object 135a indicating a change in position. In this 
example, the editor 131 determines task proximity based on identity of data files with a 
10 determined time period; here, identity of function within the editor 131 is not required. In this 
example then, the message from the editor 131a to the encounter proxy object 135a indicates the 
new position based on data file X, and this position will be called "position X." In other 
embodiments, the function being used by the editor 131 or other application would be included 
in the position. 

15 The encounter proxy object 1 35a sends 807 a status message with the current position X, 

and editor 131a name to the encounter server 141a. The encounter server 14 la searches 805 its 
stored messages 8 12a to determine if there arc any messages indicating the same application type 
as editor 13 la, or alternatively, application name, for a more limited task proximity function. If a 
status message is found with the same application type/name, the encounter server 141a invokes 

2\) 821 the match object 133a to determine whether the position of the worker associated with the 
located status message is the same as worker A's position, position X. The encounter server 141a 
passes in the position of the other worker as taken from the found status message. 

In this case, the encounter server Hla finds a status message (previously received) 
indicating that worker B is also using an editor, editor 131b, but with data file Y. and hence at 

25 position Y. Again, the editors may have the same name, or the same type. The match object 
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133a has access to the current position of worker A, position X, since it is associated with editor 
131a The match object 13 la determines that position X and position Y are not the same, and 
returns 823 a task proximity flag so indicating. Thus, worker B does not appear at this point iri 
encounter window 1 43a, nor does worker A appear in encounter window 143b. 

5 The encounter server 14 la sends 813 a status message indicating worker A's current 

position. Again, this status message includes a handle to worker A's person object 137a, the 
identification number of worker's computer, a timestamp, the name of editor 141a, and position 
X. Encounter server 131b receives this message, and replaces 819 the previous status message 
for worker A with the current one. Since the previous position for worker A was null, there is no 

id need to update the encounter window 143a. 

The encounter server 14 lb compares the new status message, and the application 
type/name specified therein, with the current application type/name, here editor 131b. These 
match, and the encounter server J 41b invokes 825 the match object 133b associated with the 
editor 13 lb, passing in position X from the received status message. The match object 1 33b 

is compares the positions, position X and position Y, and determines that there is no match, and so 
informs the encounter server 141b. Accordingly, there is no need to update worker B's encounter 
window 143b. 

Worker A now loads 827 data file Y. Again, the editor 13 la informs 803 its encounter 
proxy object 135a of the new position, position Y, and the encounter proxy object 135a sends 

20 807 a status message with the position information to the encounter server 141a. When the 
encounter server J 4 la searches 805 its stored messages, the encounter server 1 41 a identifies a 
message indicating that worker B also is using an editor 131. The encounter server (41a invokes 
821 the match object 133a, which determines that position Y of worker B matches position Y of 
worker A. returning 823 a task proximity flag to this effect. The encounter server 14 la sends 

25 811 a message with a handle to worker B*s person object client and representation (icon or the 
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like) to its encounter window 143a, which then displays the representation. Worker A can now 
see that worker B is task proximate to her. The tiroestamp included in the status message may be 
used by the encounter window 143a to order the appearance of the representations of worker B 
and others. 

s The encounter server 141a also sends 813 the status message with worker A's current 

position Y to other encounter servers 141. The encounter server 14 lb receives this message, 
compares 815 it to previous stored messages, and passes 825 the message to the match object 
133b along with the position from the previous status message specifying worker B's position. 
This match object 133b also matches the positions of workers A and B as being task proximate. 

w The encounter server 141b sends 817 a message to the encounter window I43b with the handle 
to worker A's person object client 137a and icon, and worker B's encounter window 143b 
updates itself with the representation of worker A. 

If worker A desires to interact with worker B . worker A can initiate a video conference or 
other communication mechanism using one of the buttons on the encounter window 143 or 

75 business card of worker B. The encounter server 141 a stores, in the status messages, the object 
reference to worker B and machine identification number of worker B's computer. When 
requested, the server 141a will use these values to connect to a communication service on worker 
B's computer. 

If a user places their encounter window 143 in the closed mode, their encounter server 
20 141 continues to receive 8 13 and store status messages. This allows the encounter server 1 4 1 to 
maintain the current state of the mechanism, and thereby update the encounter window 143 if and 
when the user places their encounter window 143 in the minimal or open mode. In addition, 
when placed in closed mode, the encounter server 143 sends out a status message with a null 
position for the user, so that the user is no longer task proximate to any other users. Accordingly. 
2S the encounter windows 143 of other users will be updated. 
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Where the user places the encounter window 143 in the minimal mode, encounter server 
141 adds a flag to the status messages it sends out indicating the minimal mode for the worker. 
When other encounter servers 141 receive this flag in a status message, each encounter server 
141 informs its associated encounter window 143 of this flag for a particular user. Each 
5 encounter window 143 then updates its display with a suitable representation of the minimal 
mode, such as the silhouette 42. 

Referring again to Figure 7, in the preferred embodiment, person objects 137 are formed 
in two parts: a lightweight client component, and a more heavyweight server component. The 
client component provides an address to the server component, and various operations to 

10 optimize performance, such as caching the user's representation to reduce the time required to 
update the encounter window 143. and to connect to the communication services. Pasting the 
person object 137 generally consists in pasting the address of the server component. 

Person object clients arc communicated between users, encounter-aware applications, and 
the encounter windows 143. When a person object client is asked for a value, for example a 

75 name, the client accesses the person object 137 server which then returns the value to the client, 
which in turn forwards it the requesting objecL Thus, when the encounter window 143 is 
updating itself, it will obtain the data for the representation from the server component of the 
person object 137 if there is not already a representation available in the local person object 137 
client. In a preferred implementation person object 137 clients can cache immutable (or very 

20 rarely changing) values, for example, the user name, or iconic representation. Other information 
that depends on executing processes or behaviors are not cached, such as status flag or current 
activity level. Person object 137 clients preferably provide only read operations to other objects, 
and do not allow .such objects to update the values. The person object 137 server is controlled by 
the worker whom it represents, and this person is allowed to update values in the server through a 

25 suitable interface. 
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The above description is illustrative and no! restrictive. Many variations Df the invention 
will be apparent to those of skill in the art upon review of this disclosure. The scope of the 
invention should, therefore, be determined with reference to the appended claims, along with 
their full scope of equivalents, and not merely with reference to the above description, 
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Brief Description of the Drawings 

Figure 1 is an illustration of an encounter window, on a computer display, in open mode, 
compact format, according to an embodiment of me present invention. 

Figure 2 is an illustration of a task space. 
5 Figure 3 is an illustration of the encounter window in open mode format. 

Figure 4 is an illustration of another embodiment of the encounter window providing 
search and son mechanisms in the open mode, extended format. 

Figures 5a and 5b are illustrations of the encounter window in a minimal mode. 

Figure 6 is a block diagram of the hardware elements of a computer system supporting 
10 the present invention. 

Figure 7 is an object model of the system architecture for one aspect of the present 
invention. 

Figure 8 is an event trace illustrating the typical behavior of the encounter mechanism. 
Figure 9 is a set of icons illustrating various levels of availability. 
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Abstract of the Disclosure 

A. computer system and method provide networked computer users with information 
about which other users are task proximate to the user, thereby facilitating spontaneous 
communications regarding task-related, or other, issues. The information about other users is 

5 displayed in a user interface window on each computer that presents a visual representation of 
each user who is task proximate to the user operating the computer. Task proximity to other 
users may change as the user context switches between applications, and the user interface 
window is updated accordingly. Task proximity is determined individually by different 
applications. One exemplary system architecture for providing the information includes a person 

JO object representing each user, and storing the visual representation of the user. An encounter 
window on each computer displays the visual representations. A number of encounter-aware 
applications may execute on each computer. An encounter server on each computer provides 
communication between the encounter-aware applications of the positions of each user, position 
being deiermined, for example, by the function the user is using, the data, and the lime, At least 

15 one encounter-aware application includes a match object that accepts information from the 
encounter servers about user positions and determines the task proximity of the users. The match 
object informs the encounter server of the task proximity of the user. The encounter server then 
updates the appropriate encounter window. The encounter windows further provide a number of 
communication mechanisms so that users can efficiently contact those other users who are task 

2D proximaie. 
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